Gym102059A Coloring Roads

Gym102059A Coloring Roads


题意:\(n\)点的树,一开始每条边都没有颜色,有\(Q\)个操作,每次将从\(u\)\(1\)路径上的所有边全部染色为颜色\(c\),之后询问整棵树上,出现了\(m\)次的颜色有多少种。数据范围均是\(200000\)

做法:询问的东西十分奇怪没有办法下手,于是注意到每次的修改都是染色,而且染色的路径也很特殊。于是我们猜测在这种操作方式下,一条路径上连续相同的颜色段数有一个比较优秀的期望值。先考虑如何在一个序列上,进行赋值操作,我们想到了\(ODT\),在修改的同时维护每种颜色出现的次数和每种次数对应的颜色的种类数。对于每次询问的路径,通过树剖把问题转化到为序列上处理。。。

#include <bits/stdc++.h>
#define rep(i,a,b) for(int i = a; i <= b; ++i)
#define pb push_back
typedef long long ll;
const int N = 1 << 18 | 5;
template<class T> inline void read(T &x) {x = 0; char c = getchar(); T f = 1;while(!isdigit(c)) {if(c == '-') f = -1; c = getchar();}while(isdigit(c)) {x = x * 10 + c - '0'; c = getchar();}x *= f;
}
using namespace std;
int n, C, Q;
vector<int> G[N];
int id[N], dfn, top[N], fa[N], sz[N], son[N];
void dfs1(int u, int pre) {sz[u] = 1; fa[u] = pre;int weight = 0;for(int v: G[u]) if(v != pre) {dfs1(v, u);sz[u] += sz[v];if(weight < sz[v]) weight = sz[v], son[u] = v;}
}
void dfs2(int u, int tp) {top[u] = tp; id[u] = ++dfn;if(son[u]) dfs2(son[u],tp);for(int v: G[u]) if(v != fa[u] && v != son[u]) {dfs2(v,v);}
}
int ans[N], col[N];
struct Seg{int l, r, c;bool operator < (const Seg &a) const {return r < a.r;}
};
set< Seg > S;
void split(int p) {auto s = S.lower_bound({p,p});if(s == S.end() || (s->l) > p || p == s->r) return;int L = s->l, R = s->r, C = s->c;S.erase(s); S.insert({L,p,C}); S.insert({p+1,R,C});
}
void update(int L, int R, int C) {split(L-1); split(R);while(1) {auto s = S.lower_bound({L,L});if(s == S.end() || (s->l) > R) break;if(s->c) {-- ans[col[s->c]];col[s->c] -= s->r - s->l + 1;++ ans[col[s->c]];}S.erase(s);}-- ans[col[C]];col[C] += R-L+1;++ ans[col[C]];S.insert({L,R,C});
}
void solve(int u, int c) {while(u > 1) {int L = max(id[top[u]],2), R = id[u];if(L <= R) update(L,R,c);u = fa[top[u]];}
}
int main() {read(n), read(C), read(Q);rep(i,2,n) { int u, v;read(u), read(v);G[u].pb(v), G[v].pb(u);}dfs1(1,0); dfs2(1,1);ans[0] = C;S.insert({2,n,0});while(Q--) { int u, c, m;read(u), read(c), read(m);solve(u,c);printf("%d\n",ans[m]);}
}

转载于:https://www.cnblogs.com/RRRR-wys/p/10487085.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/320429.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【树形区间DP】加分二叉树(ssl 1033/luogu 1040)

加分二叉树 ssl 1033 luogu 1040 题目大意&#xff1a; 有一棵中序遍历为1,2,3…n的二叉树&#xff08;当然二叉树的样子没有固定&#xff09;&#xff0c;现在给出每个节点的分数&#xff0c;一个节点的加数两个子节点的加数相乘当前节点的分数&#xff08;空的子节点加数…

jzoj5699-[GDOI2018day1]涛涛接苹果【树套树】

正题 题目链接:https://gmoj.net/senior/#main/show/5699 题目大意 一棵树&#xff0c;每个节点有权值&#xff0c;每天所有权值会往它的父节点滑一位&#xff0c;然后有操作会在某一天的某个节点加权值。 然后询问若干次某个时间一个位置的子树权值和。 解题思路 因为每次…

【每日一题】4月8日题目精讲 黑白树

试题链接 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 32768K&#xff0c;其他语言65536K 64bit IO Format:%lld 题目描述 一棵n个点的有根树&#xff0c;1号点为根&#xff0c;相邻的两个节点之间的距离为1。树上每个节点i对应一个值k[i]。每…

C#中字段、属性、只读、构造函数赋值、反射赋值的相关

C#中字段、属性和构造函数赋值的问题提出问题首先提出几个问题&#xff1a;1、如何实现自己的注入框架&#xff1f;2、字段和自动属性的区别是什么&#xff1f;3、字段和自动属性声明时的直接赋值和构造函数赋值有什么区别&#xff1f;4、为什么只读字段和只读自动属性&#xf…

点分治学习笔记

点分治学习笔记 模板题[洛谷P3806] 题意&#xff1a;给定一棵有n个点的树&#xff0c;询问树上距离为k的点对是否存在。 做法&#xff1a;对于一个点\(u\)&#xff0c;树上所有的路径可以分为两类&#xff0c;一类是经过点\(u\)&#xff0c;另一类是没有经过点\(u\)&#xff0c…

【暴力】心中报情(jzoj 2317)

心中报情 jzoj 2317 题目大意&#xff1a; 在一个n*m矩阵中&#xff0c;有k个选定的子矩阵&#xff0c;每个矩阵有一个代价&#xff0c;现在让你选两个子矩阵&#xff08;有相交的&#xff09;&#xff0c;使他们覆盖的元素之和减去他两的代价最大&#xff08;重复的只算一次…

BZOJ1251 序列终结者

BZOJ1251 序列终结者 题目&#xff1a;1. 将\([L,R]\)这个区间内的所有数加上\(V\)。 2. 将\([L,R]\)这个区间翻转。 3. 求\([L,R]\)这个区间中的最大值。 最开始所有元素都是\(0\)。 存个模板 Code #include <cstdio> #include <algorithm> #include <cstring&…

jzoj5698-[gdoi2018day1]密码锁【贪心,差分】

正题 题目大意 nnn个数字&#xff0c;每次可以让一个区间加或减111。然后数字是一个[0,m−1][0,m-1][0,m−1]的循环&#xff0c;求最少次数让所有数字变成000 解题思路 我们做一个%m\%m%m意义下的差分数组之后问题就变成了选择两个位置一增一减使得所有的变成000。 那么我们可…

.NET Core开发日志——RequestDelegate

本文主要是对.NET Core开发日志——Middleware的补遗&#xff0c;但是会从看起来平平无奇的RequestDelegate开始叙述&#xff0c;所以以其作为标题&#xff0c;也是合情合理。RequestDelegate是一种委托类型&#xff0c;其全貌为public delegate Task RequestDelegate(HttpCont…

[SDOI2008]仪仗队

牛客网 题目描述 作为体育委员&#xff0c;C君负责这次运动会仪仗队的训练。 仪仗队是由学生组成的N * N的方阵&#xff0c;为了保证队伍在行进中整齐划一&#xff0c;C君会跟在仪仗队的左后方&#xff0c;根据其视线所及的学生人数来判断队伍是否整齐(如下图)。 现在&#xff…

【贪心】失意(jzoj 2318)

失意 jzoj 2318 题目大意&#xff1a; 在x轴上给出n条线段&#xff0c;让你选m条线段&#xff0c;使他们的相交部分尽量大 输入样例&#xff1a; 4 6 3 3 8 4 12 2 6 1 10 5 9 11 12输出样例&#xff1a; 4 1 2 4解题思路&#xff1a; 我们先从左到右选m条线段&#xff…

Link Cut Tree 学习笔记

Link Cut Tree 学习笔记 说在前边 最近补 CF 碰见一道 LCT &#xff0c;就打算学习一下这个东西。。。顺便复习一下 splay。 具体算法及实现 参考了FlashHu&#xff0c; Candy? P3690 【模板】Link Cut Tree &#xff08;动态树&#xff09; 题目&#xff1a;给定n个点以及每个…

.NetCore SkyWalking APM实现服务器监控环境安装及基础使用

下载Java 8 SDK wget --no-cookies --no-check-certificate --header "Cookie: gpw_e24http%3A%2F%2Fwww.oracle.com%2F; oraclelicenseaccept-securebackup-cookie" http://download.oracle.com/otn-pub/java/jdk/8u171-b11/512cd62ec5174c3487ac17c61aaa89e8/jdk…

P1129-[ZJOI2007]矩阵游戏【最大匹配】

正题 题目链接:https://www.luogu.com.cn/problem/P1129 题目大意 n∗mn*mn∗m的网格上有0/10/10/1&#xff0c;可以选择交换两行或两列&#xff0c;求能否让对角线上全是111。 解题思路 因为可以交换&#xff0c;所以是每一行都要和每一列配对。而第iii行能够和第jjj列配对的…

身体训练

牛客网 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 32768K&#xff0c;其他语言65536K 64bit IO Format: %lld 题目描述 美团外卖的配送员用变速跑的方式进行身体训练。 他们训练的方式是&#xff1a;n个人排成一列跑步&#xff0c;前后两人…

ASP.NET Core依赖注入最佳实践,提示技巧

分享翻译一篇Abp框架作者(Halil İbrahim Kalkan)关于ASP.NET Core依赖注入的博文.在本文中,我将分享我在ASP.NET Core应用程序中使用依赖注入的经验和建议.这些原则背后的目的是:有效地设计服务及其依赖关系防止多线程问题防止内存泄漏防止潜在的错误本文假设你已经熟悉基本的…

【匈牙利算法】指引(jzoj 2319)

指引 jzoj 2319 题目大意&#xff1a; 在平面上有n个人和出口&#xff0c;一个出口只能让一个人进&#xff0c;每个人只能向右向上走&#xff0c;问最多让多少个人到出口 输入样例&#xff1a; 6 3 2 0 3 1 1 3 4 2 0 4 5 5输出样例&#xff1a; 2解题思路&#xff1a; …

Codeforces1142D

Codeforces1142D 做法&#xff1a;构建一个可以识别出合法串的自动机&#xff0c;然后就可以想办法在上边 dp 出答案。 首先&#xff0c;按照最直观的思路画一画这个自动机&#xff0c;找到每一个状态s如何推出它的后继t&#xff0c;然后通过状态的转移方式&#xff0c;找到等价…

P3620-[APIO/CTSC2007]数据备份【贪心,堆,链表】

正题 题目链接:https://www.luogu.com.cn/problem/P3620 题目大意 一条线上有nnn个位置&#xff0c;选出kkk对使得它们的距离差之和最小。 解题思路 因为一定是连接相邻的最优&#xff0c;那么可以在差分数组上做&#xff0c;相当于我们在一个差分数组上选择一些不相邻的数使…

Maximize The Beautiful Value

传送 时间限制&#xff1a;C/C 2秒&#xff0c;其他语言4秒 空间限制&#xff1a;C/C 131072K&#xff0c;其他语言262144K 64bit IO Format:%lld 题目描述 Today HH finds a non-decreasing sequence(a1,a2…an,ai≤ai1), he thinks it’s not beautiful so he wants to make …