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

唯一注意的是线段树的更新,因为同一子树中可能有多种颜色占主导地位,要输出编号和,比如一颗子树中,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. angular 变化检测和ngZone

  2. Javaweb-JSP详解

    一.什么是JSP Java Server Pages:Java服务器端页面,和Servlet一样,用于动态web技术 最大的特点: 写JSP就像在写HTML 区别: HTML只给用户提供静态的数据 J ...

  3. Nginx 文件传输效率、实时、压缩配置指令

    # sendfile 开启文件高效传输模式 # 默认值:off # 位置:http.servcer.location-- # 开启和不开启worker访问的文件发送到浏览器的过程不同. # 不开启的时 ...

  4. 使用.NET简单实现一个Redis的高性能克隆版(一)

    译者注 该原文是Ayende Rahien大佬业余自己在使用C# 和 .NET构建一个简单.高性能兼容Redis协议的数据库的经历. 首先这个"Redis"是非常简单的实现,但是他 ...

  5. vue脚手架创建项目后使用路由报错Object(...) is not a function问题

    在这之前我做过的vue项目没有这种问题,今天突然出现这个问题,也检查了很久的代码,最后解决我也不知道我是哪一步做错了 首先我是创建的vue2项目,基本操作跟平常一样,在运用路由跳转的时候遇到这个问题 ...

  6. Luogu3802 小魔女帕琪 (排列组合)

    注意除数为0情况 #include <iostream> #include <cstdio> #include <cstring> #include <alg ...

  7. Luogu1527 [国家集训队]矩阵乘法 (整体二分)(Unfinished)

    全线RE的代码... 先搁这吧,下次再说.flag //#include <iostream> #include <cstdio> //#include <cstring ...

  8. java中使用 POI导出excel表格的简单实现

    大概流程分7步: 1.创建工作簿 --> 2.创建sheet表 --> 3.创建row行(建议使用循环) --> 4.用row行逐一创建单元格(建议使用循环) --> 5.单元 ...

  9. 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况

    1.   安装JMeter及使用 1.1下载JMeter 登录官方网站找到下载链接进行下载:https://jmeter.apache.org/download_jmeter.cgi 1.2配置环境变 ...

  10. 漏洞扫描工具awvs13破解

    AWVS13_windows破解版:链接:https://pan.baidu.com/s/1qeGiNubhWgY6oeMx_IkMtg 提取码:2i2o AWVS13_linux破解版:链接:htt ...