Codeforces 600E. Lomsat gelral

学习了一下dsu on tree

所以为啥是dsu而不是dfs on tree???

这道题先把这棵树轻重链剖分了,然后先处理轻儿子,处理完轻儿子后要把轻儿子的贡献都给删了

然后为了计算这个点的贡献,我把所有轻儿子的贡献加回来

如果这个点是个轻儿子,没什么人权,我就再遍历整棵树把它清空

其实我希望的是把整个数组清空,又不能一个一个清,所以把当前子树遍历一遍清空

唔,感觉说的好短,但是确实是这样的……

  1. #include <bits/stdc++.h>
  2. #define fi first
  3. #define se second
  4. #define pii pair<int,int>
  5. #define mp make_pair
  6. #define pb push_back
  7. #define space putchar(' ')
  8. #define enter putchar('\n')
  9. #define eps 1e-10
  10. #define MAXN 100005
  11. #define ba 47
  12. //#define ivorysi
  13. using namespace std;
  14. typedef long long int64;
  15. typedef unsigned int u32;
  16. typedef double db;
  17. template<class T>
  18. void read(T &res) {
  19. res = 0;T f = 1;char c = getchar();
  20. while(c < '0' || c > '9') {
  21. if(c == '-') f = -1;
  22. c = getchar();
  23. }
  24. while(c >= '0' && c <= '9') {
  25. res = res * 10 +c - '0';
  26. c = getchar();
  27. }
  28. res *= f;
  29. }
  30. template<class T>
  31. void out(T x) {
  32. if(x < 0) {x = -x;putchar('-');}
  33. if(x >= 10) {
  34. out(x / 10);
  35. }
  36. putchar('0' + x % 10);
  37. }
  38. struct node {
  39. int to,next;
  40. }E[MAXN * 2];
  41. int head[MAXN],sumE;
  42. int N,c[MAXN],siz[MAXN],son[MAXN];
  43. int val[MAXN],mval;
  44. int64 sum,ans[MAXN];
  45. bool vis[MAXN];
  46. void add(int u,int v) {
  47. E[++sumE].to = v;
  48. E[sumE].next = head[u];
  49. head[u] = sumE;
  50. }
  51. void dfs(int u,int fa) {
  52. siz[u] = 1;
  53. for(int i = head[u] ; i ; i = E[i].next) {
  54. int v = E[i].to;
  55. if(v != fa) {
  56. dfs(v,u);
  57. siz[u] += siz[v];
  58. if(siz[v] > siz[son[u]]) son[u] = v;
  59. }
  60. }
  61. }
  62. void change(int u,int fa,int k) {
  63. val[c[u]] += k;
  64. if(k == -1) vis[u] = 0;
  65. if(val[c[u]] >= mval) {
  66. if(val[c[u]] > mval) {mval = val[c[u]];sum = 0;}
  67. sum += c[u];
  68. }
  69. for(int i = head[u] ; i ; i = E[i].next) {
  70. int v = E[i].to;
  71. if(v != fa && (!vis[v] || k == -1)) {
  72. change(v,u,k);
  73. }
  74. }
  75. }
  76. void calc(int u,int fa,bool f) {
  77. for(int i = head[u] ; i ; i = E[i].next) {
  78. int v = E[i].to;
  79. if(v != fa && v != son[u]) {
  80. calc(v,u,0);
  81. }
  82. }
  83. if(son[u]) {calc(son[u],u,1);vis[son[u]] = 1;}
  84. change(u,fa,1);
  85. ans[u] = sum;
  86. if(!f) {change(u,fa,-1);sum = 0;mval = 0;}
  87. }
  88. void Solve() {
  89. read(N);
  90. for(int i = 1 ; i <= N ; ++i) read(c[i]);
  91. int a,b;
  92. for(int i = 1 ; i < N ; ++i) {
  93. read(a);read(b);
  94. add(a,b);add(b,a);
  95. }
  96. dfs(1,0);
  97. calc(1,0,1);
  98. for(int i = 1 ; i <= N ; ++i) {
  99. out(ans[i]);space;
  100. }
  101. enter;
  102. }
  103. int main() {
  104. #ifdef ivorysi
  105. freopen("f1.in","r",stdin);
  106. #endif
  107. Solve();
  108. }

【Codeforces】600E. Lomsat gelral的更多相关文章

  1. 【cf600】E. Lomsat gelral(dsu on tree)

    传送门 题意: 求子树众数. 思路: \(dsu\ on\ tree\)模板题,用一个桶记录即可. 感觉\(dsu\ on\ tree\)这个算法的涉及真是巧妙呀,保留重链的信息,不断暴力轻边,并且不 ...

  2. 【CodeForces】600 E. Lomsat gelral (dsu on tree)

    [题目]E. Lomsat gelral [题意]给定n个点的树,1为根,每个点有一种颜色ci,一种颜色占领一棵子树当且仅当子树内没有颜色的出现次数超过它,求n个答案——每棵子树的占领颜色的编号和Σc ...

  3. Codeforces 600E - Lomsat gelral(树上启发式合并)

    600E - Lomsat gelral 题意 给出一颗以 1 为根的树,每个点有颜色,如果某个子树上某个颜色出现的次数最多,则认为它在这课子树有支配地位,一颗子树上,可能有多个有支配的地位的颜色,对 ...

  4. 【Codeforces】Round #491 (Div. 2) 总结

    [Codeforces]Round #491 (Div. 2) 总结 这次尴尬了,D题fst,E没有做出来.... 不过还好,rating只掉了30,总体来说比较不稳,下次加油 A:If at fir ...

  5. 【Codeforces】Round #488 (Div. 2) 总结

    [Codeforces]Round #488 (Div. 2) 总结 比较僵硬的一场,还是手速不够,但是作为正式成为竞赛生的第一场比赛还是比较圆满的,起码没有FST,A掉ABCD,总排82,怒涨rat ...

  6. Codeforces 600E Lomsat gelral (树上启发式合并)

    题目链接 Lomsat gelral 占坑……等深入理解了再来补题解…… #include <bits/stdc++.h> using namespace std; #define rep ...

  7. 【CodeForces】601 D. Acyclic Organic Compounds

    [题目]D. Acyclic Organic Compounds [题意]给定一棵带点权树,每个点有一个字符,定义一个结点的字符串数为往下延伸能得到的不重复字符串数,求min(点权+字符串数),n&l ...

  8. 【Codeforces】849D. Rooter's Song

    [算法]模拟 [题意]http://codeforces.com/contest/849/problem/D 给定n个点从x轴或y轴的位置p时间t出发,相遇后按对方路径走,问每个数字撞到墙的位置.(还 ...

  9. Codeforces 600 E - Lomsat gelral

    E - Lomsat gelral 思路1: 树上启发式合并 代码: #include<bits/stdc++.h> using namespace std; #define fi fir ...

随机推荐

  1. MIME协议(二)

    MIME协议 RFC822文档定义了邮件内容的主体结构和各种邮件头字段的详细细节,但是,它没有定义邮件体的格式,RFC822文档定义的邮件体部分通常都只能用于表述一段普通的文本,而无法表达出图片.声音 ...

  2. ie8中如何使用base64

    由于ie8中不能使用jQuery2.0以上版本所以无法使用 window.btoa()加密 window.atob()解密 所以只能使用最原生的base64加密方法如下: /** * Created ...

  3. Python入门(下载编译器,并安装)

    进入官网 https://www.python.org/ 当前:官网上面的版本是3.7.3 在Windows上面安装比较简单,就一直点下一步就ok了 我这边是选的第一个, 我学习的教程建议我用第二个, ...

  4. java TimeUnit 的使用

    主要作用 时间颗粒度转换 延时 1.时间颗粒度转换 public long toMillis(long d) //转化成毫秒 public long toSeconds(long d) //转化成秒 ...

  5. Linux-ubuntu英文版输入法不能切换中文输入法问题解决办法

    1:System Settings中点击Language Support​ 2. ​ 3. ​ 4. ​ 5. ​ 6. ​ 7.注意不要勾选Only Show Current Language ​

  6. 【零基础】speech driven animation中文安装使用指南

    注:原项目名叫Speech-Driven Animation,所以我这里就简称为SDA 开局一张图,后面自动编 相信前段时间爆火的DeepNude(AI扒衣)让很多人惊掉了大牙,AI还能干这个?!如果 ...

  7. Centos镜像下载地址

    https://blog.csdn.net/weixin_42430824/article/details/81019039

  8. 性能测试 | 理解单线程的Redis为何那么快?

    前言 Redis是一种基于键值对(Key-Value)的NoSQL数据库,Redis的Value可以由String,hash,list,set,zset,Bitmaps,HyperLogLog等多种数 ...

  9. k8s部署03-----常用运维命令

    kubectl常用命令 kubectl get nodes #查看集群中有多少个node kubectl describe node <node_name> #查看某个node的详细信息 ...

  10. 编译原理 DFA(确定性有穷自动机)&& NFA(非确定性有穷自动机)

    https://www.cnblogs.com/fpcbk/p/11004913.html