CF600E Lomsat gelral (线段树合并)
相当于是线段树合并的模板题,比(雨天的尾巴)还要板。
唯一注意的是线段树的更新,因为同一子树中可能有多种颜色占主导地位,要输出编号和,比如一颗子树中,1出现3次(最多),3出现3次,那么应该输出4。
1 #include<bits/stdc++.h>
2 #define ll long long
3 using namespace std;
4 const int N = 1e5 + 10, M = 1e5;
5 struct node {
6 int lc, rc;
7 ll dat, num;//dat次数最多颜色的次数,num编号和
8 }tr[N * 50];
9 int head[N], to[N << 1], nxt[N << 1], tot;
10 int n, rt[N], cnt, co[N];
11 ll ans[N];
12 void add(int x, int y) {
13 nxt[++tot] = head[x];
14 head[x] = tot;
15 to[tot] = y;
16 }
17
18 void pushup(int k) {//注意
19 node a = tr[tr[k].lc], b = tr[tr[k].rc];
20 if (a.dat > b.dat) {
21 tr[k].dat = a.dat;
22 tr[k].num = a.num;
23 }
24 else if (a.dat < b.dat) {
25 tr[k].dat = b.dat;
26 tr[k].num = b.num;
27 }
28 else {
29 tr[k].dat = a.dat;
30 tr[k].num = a.num + b.num;
31 }
32 }
33
34 void insert(int p, int l, int r, int pos, int val) {
35 if (l == r) {
36 tr[p].dat += val;
37 tr[p].num = l;
38 return ;
39 }
40 int mid = (l + r) >> 1;
41 if (pos <= mid) {
42 if (!tr[p].lc) tr[p].lc = ++cnt;
43 insert(tr[p].lc, l, mid, pos, val);
44 }
45 else {
46 if (!tr[p].rc) tr[p].rc = ++cnt;
47 insert(tr[p].rc, mid + 1, r, pos, val);
48 }
49 pushup(p);
50 }
51
52 int merge(int p, int q, int l, int r) {
53 if (!p || !q) return p + q;
54 if (l == r) {
55 tr[p].dat += tr[q].dat;
56 tr[p].num = l;
57 return p;
58 }
59 int mid = (l + r) >> 1;
60 tr[p].lc = merge(tr[p].lc, tr[q].lc, l, mid);
61 tr[p].rc = merge(tr[p].rc, tr[q].rc, mid + 1, r);
62 pushup(p);
63 return p;
64 }
65
66 void dfs(int u, int f) {
67 for (int i = head[u]; i; i = nxt[i]) {
68 int v = to[i];
69 if (v == f) continue;
70 dfs(v, u);
71 rt[u] = merge(rt[u], rt[v], 1, M);
72 }
73 ans[u] = tr[rt[u]].num;
74 }
75
76 int main() {
77 scanf("%d", &n);
78 for (int i = 1; i <= n; i++) {
79 scanf("%d", &co[i]);
80 rt[i] = ++cnt;
81 insert(rt[i], 1, M, co[i], 1);
82 }
83 for (int i = 1; i < n; i++) {
84 int a, b;
85 scanf("%d%d", &a, &b);
86 add(a, b),add(b, a);
87 }
88 dfs(1, 0);
89 for (int i = 1; i <= n; i++) printf("%lld ", ans[i]);
90 return 0;
91 }
92 /*
93 4
94 1 2 3 4
95 1 2
96 2 3
97 2 4
98 */
CF600E Lomsat gelral (线段树合并)的更多相关文章
- CF600E:Lomsat gelral(线段树合并)
Description 一棵树有n个结点,每个结点都是一种颜色,每个颜色有一个编号,求树中每个子树的最多的颜色编号的和. Input 第一行一个$n$.第二行$n$个数字是$c[i]$.后面$n-1$ ...
- CF600E Lomsat gelral——线段树合并/dsu on tree
题目描述 一棵树有$n$个结点,每个结点都是一种颜色,每个颜色有一个编号,求树中每个子树的最多的颜色编号的和. 这个题意是真的窒息...具体意思是说,每个节点有一个颜色,你要找的是每个子树中颜色的众数 ...
- codeforces 600E . Lomsat gelral (线段树合并)
You are given a rooted tree with root in vertex 1. Each vertex is coloured in some colour. Let's cal ...
- CodeForces600E Lomsat gelral 线段树合并
从树上启发式合并搜出来的题 然而看着好像线段树合并就能解决??? 那么就用线段树合并解决吧 维护\(max, sum\)表示值域区间中的一个数出现次数的最大值以及所有众数的和即可 复杂度\(O(n \ ...
- CF600E Lomsat gelral 树上启发式合并
题目描述 有一棵 \(n\) 个结点的以 \(1\) 号结点为根的有根树. 每个结点都有一个颜色,颜色是以编号表示的, \(i\) 号结点的颜色编号为 \(c_i\). 如果一种颜色在以 \(x\) ...
- CF600E Lomsat gelral 【线段树合并】
题目链接 CF600E 题解 容易想到就是线段树合并,维护每个权值区间出现的最大值以及最大值位置之和即可 对于每个节点合并一下两个子节点的信息 要注意叶子节点信息的合并和非叶节点信息的合并是不一样的 ...
- codeforces 600E E. Lomsat gelral (线段树合并)
codeforces 600E E. Lomsat gelral 传送门:https://codeforces.com/contest/600/problem/E 题意: 给你一颗n个节点的树,树上的 ...
- BZOJ.3307.雨天的尾巴(dsu on tree/线段树合并)
BZOJ 洛谷 \(dsu\ on\ tree\).(线段树合并的做法也挺显然不写了) 如果没写过\(dsu\)可以看这里. 对修改操作做一下差分放到对应点上,就成了求每个点子树内出现次数最多的颜色, ...
- [XJOI NOI2015模拟题13] C 白黑树 【线段树合并】
题目链接:XJOI - NOI2015-13 - C 题目分析 使用神奇的线段树合并在 O(nlogn) 的时间复杂度内解决这道题目. 对树上的每个点都建立一棵线段树,key是时间(即第几次操作),动 ...
随机推荐
- api.versioning 版本控制 自动识别最高版本和多Area但同名Contoller问题解决办法
Microsoft.AspNetCore.Mvc.Versioning //引入程序集 .net core 下面api的版本控制作用不需要多说,可以查阅https://www.cnblogs.com/ ...
- 开发了一个安卓小软件“CSV联系人导入导出工具”,欢迎测试
开发了一个安卓小软件"CSV联系人导入导出工具",欢迎测试.本软件可以帮你快速备份和恢复联系人,不用担心号码遗失,软件操作简单,使用方便. 下载地址: 百度网盘:https://p ...
- 面试突击73:IoC 和 DI 有什么区别?
IoC 和 DI 都是 Spring 框架中的重要概念,就像玫瑰花与爱情一样,IoC 和 DI 通常情况下也是成对出现的.那 IoC 和 DI 什么关系和区别呢?接下来,我们一起来看. 1.IoC 介 ...
- React报错之Cannot find namespace context
正文从这开始~ 总览 在React中,为了解决"Cannot find namespace context"错误,在你使用JSX的文件中使用.tsx扩展名,在你的tsconfig. ...
- 使用 Less 混合(Mixins)时报语法错误
今天在尝试使用 less 的混合语法时,浏览器直接报了一个语法错误.下图是报错信息: 仔细地阅读了官方文档,和对比自己写的,并没有任何错误. .FlexLayout { .Start() { disp ...
- Java jdk常用工具集合
jdk 常用工具包目录: windows: 默认安装目录:C:\Program Files\Java\jdk1.8.0_152\bin> 1.查看Java进程 jps -l 查看当前机器的Jav ...
- 从new File("")到jdk源码
1. 概述 今天在项目中看到下面两行代码,看注释说是获取当前工作路径,之前也没有用过这种用法,比较好奇还能这样用,所以研究了一下源码. //获取当前工作路径 File file = new File( ...
- linux 3个快捷方式
Ctrl+c组合键:当同时按下键盘上的Ctrl和字母c的时候,意味着终止当前进程的运行.假如执行了一个错误命令,或者是执行某个命令后迟迟无法结束,这时就可以冷静地按下Ctrl+c组合键,命令行终端的控 ...
- HDU6848改编题(弱化)——客星璀璨之夜(stars)
「 客星璀璨之夜 」(stars) " 虽然不清楚是不是那两人的力量 在那个风暴肆虐的夜晚,的确有一瞬 真的在那一瞬间,在云破天开的时候 透过空隙中看到的璀璨星空,不知为何倒映眼中不能忘怀 ...
- 网卡限速工具之WonderShaper
GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. GreatSQL是MySQL的国产分支版本,使用上与MySQL一致. 什么是WonderShaper 如何安装Wonder ...