相当于是线段树合并的模板题,比(雨天的尾巴)还要板。

唯一注意的是线段树的更新,因为同一子树中可能有多种颜色占主导地位,要输出编号和,比如一颗子树中,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 (线段树合并)的更多相关文章

  1. CF600E:Lomsat gelral(线段树合并)

    Description 一棵树有n个结点,每个结点都是一种颜色,每个颜色有一个编号,求树中每个子树的最多的颜色编号的和. Input 第一行一个$n$.第二行$n$个数字是$c[i]$.后面$n-1$ ...

  2. CF600E Lomsat gelral——线段树合并/dsu on tree

    题目描述 一棵树有$n$个结点,每个结点都是一种颜色,每个颜色有一个编号,求树中每个子树的最多的颜色编号的和. 这个题意是真的窒息...具体意思是说,每个节点有一个颜色,你要找的是每个子树中颜色的众数 ...

  3. 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 ...

  4. CodeForces600E Lomsat gelral 线段树合并

    从树上启发式合并搜出来的题 然而看着好像线段树合并就能解决??? 那么就用线段树合并解决吧 维护\(max, sum\)表示值域区间中的一个数出现次数的最大值以及所有众数的和即可 复杂度\(O(n \ ...

  5. CF600E Lomsat gelral 树上启发式合并

    题目描述 有一棵 \(n\) 个结点的以 \(1\) 号结点为根的有根树. 每个结点都有一个颜色,颜色是以编号表示的, \(i\) 号结点的颜色编号为 \(c_i\)​. 如果一种颜色在以 \(x\) ...

  6. CF600E Lomsat gelral 【线段树合并】

    题目链接 CF600E 题解 容易想到就是线段树合并,维护每个权值区间出现的最大值以及最大值位置之和即可 对于每个节点合并一下两个子节点的信息 要注意叶子节点信息的合并和非叶节点信息的合并是不一样的 ...

  7. codeforces 600E E. Lomsat gelral (线段树合并)

    codeforces 600E E. Lomsat gelral 传送门:https://codeforces.com/contest/600/problem/E 题意: 给你一颗n个节点的树,树上的 ...

  8. BZOJ.3307.雨天的尾巴(dsu on tree/线段树合并)

    BZOJ 洛谷 \(dsu\ on\ tree\).(线段树合并的做法也挺显然不写了) 如果没写过\(dsu\)可以看这里. 对修改操作做一下差分放到对应点上,就成了求每个点子树内出现次数最多的颜色, ...

  9. [XJOI NOI2015模拟题13] C 白黑树 【线段树合并】

    题目链接:XJOI - NOI2015-13 - C 题目分析 使用神奇的线段树合并在 O(nlogn) 的时间复杂度内解决这道题目. 对树上的每个点都建立一棵线段树,key是时间(即第几次操作),动 ...

随机推荐

  1. Windows环境安装Hadoop环境

    1,下载Hadoop,解压 2,配置Hadoop环境变量 右键此电脑--属性 高级系统设置 环境变量 新建一个HADOOP_HOME 添加到path 3,cmd窗口查看安装情况:hadoop vers ...

  2. PHP常见的几种攻击方式

    1.SQL Injection(sql注入) 1暴字段长度 Order by num/* 2.匹配字段 and 1=1 union select 1,2,3,4,5--.n/* 3.暴露字段位置 an ...

  3. 服务器配置IP

    1.服务器系统一般有两个或多个网卡.在企业中一般给服务器网卡配一个可连外网的IP,如172.16.20.22 255.255.255.0 172.16.20.1 方便联网下载安装部分软件,若没有VPN ...

  4. Postman如何通过xmysql工具的Restful API 接口访问MySQL

    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 导语 有时候用 Postman 接口测试需要获取MySQL的查询结果做接口输出的校验,这里介绍下 Postman 通过 R ...

  5. mongo数据同步的三种方案

    (一)直接复制data目录(需要停止源和目标的mongo服务)1.针对目标mongo服务已经存在,并正在运行的(mongo2-->mongo).执行步骤:(1).停止源/目标服务器的mongo服 ...

  6. 275. H 指数 II--Leetcode_暴力

    来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/h-index-ii 著作权归领扣网络所有.商业转载请联系官方授权,非商业转载请注明出处. 题目的大意是 ...

  7. ABC216H - Random Robots(容斥,状压DP)

    题面 有 K K K 个机器人初始分别位于数轴上 x 1 , x 2 , . . . , x K x_1,x_2,...,x_{K} x1​,x2​,...,xK​ 的整点位置. 接下来会经历 N N ...

  8. APICloud AVM框架 封装车牌号输入键盘组件

    AVM(Application-View-Model)前端组件化开发模式基于标准Web Components组件化思想,提供包含虚拟DOM和Runtime的编程框架avm.js以及多端统一编译工具,完 ...

  9. Job And Schedule (V8R6C4)

    KingbaseES 数据库提供了 kdb_schedule 扩展,使得用户能通过类似oracle job 的方式进行job调用.kdb_schedule 提供了三个Schema :dbms_job ...

  10. KingbaseES 行列转换函数

    关键字:    行专列,列转行, pivot, unpivot 行列转换是在数据分析中经常用到的一项功能,KingbaseES从V8R6C3B0071版本开始通过扩展插件(kdb_utils_func ...