【CF600E】Lomsat gelral(dsu on tree)

题面

洛谷

CF题面自己去找找吧。

题解

\(dsu\ on\ tree\)板子题

其实就是做子树询问的一个较快的方法。

对于子树的询问,我们不难想到子树就是\(dfs\)序上的连续一段,

可以把树转化成序列再用莫队来解。

其实可以对树进行树链剖分,然后暴力+优化来解

具体的做法就是:

递归处理轻儿子,计算轻儿子答案,

然后消去轻儿子对于答案的影响。

然后递归处理重儿子,不消去影响,最后加入所有轻儿子贡献,计算答案。

复杂度?

每个点会被消去影响的时候,一定是某个父亲是轻儿子

而树链剖分保证了这个次数是\(log\)次

所以复杂度是\(O(nlogn)\)优于莫队的\(O(n\sqrt n)\)

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstdlib>
  4. #include<cstring>
  5. #include<cmath>
  6. #include<algorithm>
  7. #include<set>
  8. #include<map>
  9. #include<vector>
  10. #include<queue>
  11. using namespace std;
  12. #define ll long long
  13. #define RG register
  14. #define MAX 111111
  15. inline int read()
  16. {
  17. RG int x=0,t=1;RG char ch=getchar();
  18. while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
  19. if(ch=='-')t=-1,ch=getchar();
  20. while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
  21. return x*t;
  22. }
  23. struct Line{int v,next;}e[MAX<<1];
  24. int h[MAX],cnt=1;
  25. inline void Add(int u,int v){e[cnt]=(Line){v,h[u]};h[u]=cnt++;}
  26. int size[MAX],hson[MAX],dep[MAX],fa[MAX];
  27. ll ans[MAX],sum[MAX];
  28. int num[MAX],top,c[MAX],n;
  29. bool vis[MAX];
  30. void dfs1(int u,int ff)
  31. {
  32. fa[u]=ff;dep[u]=dep[ff]+1;size[u]=1;
  33. for(int i=h[u];i;i=e[i].next)
  34. {
  35. int v=e[i].v;if(v==ff)continue;
  36. dfs1(v,u);size[u]+=size[v];
  37. if(size[v]>size[hson[u]])hson[u]=v;
  38. }
  39. }
  40. void update(int u,int ff,int opt)
  41. {
  42. sum[num[c[u]]]-=c[u];
  43. num[c[u]]+=opt;
  44. sum[num[c[u]]]+=c[u];
  45. if(sum[top+1])++top;
  46. if(!sum[top])--top;
  47. for(int i=h[u];i;i=e[i].next)
  48. if(e[i].v!=ff&&!vis[e[i].v])update(e[i].v,u,opt);
  49. }
  50. void dfs(int u,int ff,int hs)
  51. {
  52. for(int i=h[u];i;i=e[i].next)
  53. if(e[i].v!=ff&&e[i].v!=hson[u])dfs(e[i].v,u,0);
  54. if(hson[u])dfs(hson[u],u,1),vis[hson[u]]=true;
  55. update(u,ff,1);vis[hson[u]]=0;
  56. ans[u]=sum[top];
  57. if(!hs)update(u,ff,-1);
  58. }
  59. int main()
  60. {
  61. n=read();
  62. for(int i=1;i<=n;++i)c[i]=read();
  63. for(int i=1;i<n;++i)
  64. {
  65. int u=read(),v=read();
  66. Add(u,v);Add(v,u);
  67. }
  68. dfs1(1,0);dfs(1,0,1);
  69. for(int i=1;i<=n;++i)printf("%I64d ",ans[i]);puts("");
  70. return 0;
  71. }

【CF600E】Lomsat gelral(dsu on tree)的更多相关文章

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

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

  2. CF600E Lomsat gelral(dsu on tree)

    dsu on tree跟冰茶祭有什么关系啊喂 dsu on tree的模板题 思想与解题过程 类似树链剖分的思路 先统计轻儿子的贡献,再统计重儿子的贡献,得出当前节点的答案后再减去轻儿子对答案的贡献 ...

  3. Codeforces 600E Lomsat gelral(dsu on tree)

    dsu on tree板子题.这个trick保证均摊O(nlogn)的复杂度,要求资瓷O(1)将一个元素插入集合,清空集合时每个元素O(1)删除.(当然log的话就变成log^2了) 具体的,每次先遍 ...

  4. 【CF600E】 Lomsat gelral

    CF600E Lomsat gelral Solution 考虑一下子树的问题,我们可以把一棵树的dfn序搞出来,那么子树就是序列上的一段连续的区间. 然后就可以莫队飞速求解了. 但是这题还有\(\T ...

  5. 【CF600E】Lomsat gelral

    题目大意:给定一棵 N 个节点的有根树,1 号节点是树的根节点,每个节点有一个颜色.求对于每个节点来说,能够支配整棵子树的颜色之和是多少.支配的定义为对于以 i 为根的子树,该颜色出现的次数不小于任何 ...

  6. 【UOJ388】配对树(dsu on tree+线段树)

    传送门 题意: 给出一颗含有\(n\)个结点的无根树,之后给出一个长度为\(m\)的序列,每个元素在\([1,n]\)之间. 现在序列中每个长度为偶数的区间的完成时间定义为树上最小配对方法中每对匹配点 ...

  7. 【CF600E】Lomsat gelral——树上启发式合并

    (题面来自luogu) 题意翻译 一棵树有n个结点,每个结点都是一种颜色,每个颜色有一个编号,求树中每个子树的最多的颜色编号的和. ci <= n <= 1e5 裸题.统计时先扫一遍得到出 ...

  8. 【Luogu U41492】树上数颜色——树上启发式合并(dsu on tree)

    (这题在洛谷主站居然搜不到--还是在百度上偶然看到的) 题目描述 给一棵根为1的树,每次询问子树颜色种类数 输入输出格式 输入格式: 第一行一个整数n,表示树的结点数 接下来n-1行,每行一条边 接下 ...

  9. 【CF1009F】Dominant Indices(长链剖分)

    [CF1009F]Dominant Indices(长链剖分) 题面 洛谷 CF 翻译: 给定一棵\(n\)个点,以\(1\)号点为根的有根树. 对于每个点,回答在它子树中, 假设距离它为\(d\)的 ...

随机推荐

  1. 远程连接ejabberd的mnesia数据库

    由于服务器是server版本,所以很难直观的看到mnesia的数据.所以对于初学者来说非常的困惑. 特地在qq群中请教了别人.别人说只要pong通了就行,就能通过rpc去操作远程的mnesia数据库. ...

  2. openstack-r版(rocky)搭建基于centos7.4 的openstack swift对象存储服务 三

    openstack-r版(rocky)搭建基于centos7.4 的openstack swift对象存储服务 一 openstack-r版(rocky)搭建基于centos7.4 的openstac ...

  3. 记录一下自己申请并使用VPS的全过程

    在学习REST API的时候,想要阅读一下谷歌爸爸的api design guide,无奈无情被墙,正好在学习云相关的技术,就想到申请一个VPS来用用. 这次我选择的是hostmybytes,原因有两 ...

  4. 论文笔记:DeepFace: Closing the Gap to Human-Level Performance in Face Verification

    2014 CVPR Facebook AI研究院 简单介绍 人脸识别中,通常经过四个步骤,检测,对齐(校正),表示,分类 论文主要阐述了在对齐和表示这两个步骤上提出了新的方法,模型的表现超越了前人的工 ...

  5. 详讲H5、WebApp项目中常见的坑以及注意事项

    首先我们中会有一些常用的meta标签,如下: <!--防止手机中网页放大和缩小--> <meta name="viewport" content="wi ...

  6. Segments CodeForces 909B (找规律)

    Description You are given an integer N. Consider all possible segments (线段,划分)on the coordinate axis ...

  7. “Hello World!”团队第十四次会议

    今天是我们团队“Hello World!”团队召开的第十四次会议.博客内容: 一.会议时间 二.会议地点 三.会议成员 四.会议内容 五.Todo List 六.会议照片 七.燃尽图 一.会议时间 2 ...

  8. 《Linux内核分析》学习总结与学习心得

    一.目录列表 第一周:计算机是如何工作的? http://www.cnblogs.com/dvew/p/5224866.html 第二周:操作系统是如何工作的? http://www.cnblogs. ...

  9. winfrom 界面编辑之疑难杂症

    设计器方便,但是也存在一些问题: 1.找不到控件,但确实存在——被隐藏或被右键显示于底层或颜色与父容器一致. 解决办法: 修改隐藏属性或右键显示于顶层. 2.灵活运用右键锁定控件与解锁控件. 3.注意 ...

  10. winform default模式下和英文模式下 修改问题

    1.修改控件大小.位置等属性在default模式下修改: 2.修改控件属性最好不要做鼠标拖动放大,拖动修改位置等,建议用属性栏中的数字来改变.