CF620E New Year Tree 线段树 dfs序
luogu链接
题目大意:
有一个节点有颜色的树
操作1.修改子树的颜色
操作2.查询子树颜色的种类
注意,颜色种类小于60种
只有子树的操作,dfs序当然是最好的选择
dfs序列是什么,懒得讲了,自己搜吧
然后开两个数组,begin_和end_记录节点子树在dfs序数组中的开头和结尾
begin,end居然在cf是关键字,还好不是ccf,要不就死了
区间修改一个数,区间查询,线段树的傻逼操作
OK
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
#define ls rt<<1
#define rs rt<<1|1
#define ll long long
const int max4 = 2e6 + 7;
const int inf = 0x3f3f3f3f;
int n, m;
int w[max4], a[max4], begin_[max4], end_[max4];
struct node
{
int l, r, size, lazy;
ll z;
void color(int i)
{
z = z | (1LL << (i - 1));
}
void clear()
{
z = 0LL;
}
} e[max4];
struct edge_edge
{
int v, nxt;
} edge[max4];
int head[max4], e_tot;
void add_edge(int u, int v)
{
edge[++e_tot].v = v;
edge[e_tot].nxt = head[u];
head[u] = e_tot;
}
int count(ll z)
{
int js = 0;
for (; z;)
{
if (z & 1) js++;
z >>= 1;
}
return js;
}
int read()
{
int x = 0, f = 1; char s = getchar();
for (; s < '0' || s > '9'; s = getchar()) if (s == '-') f = -1;
for (; s >= '0' && s <= '9'; s = getchar()) x = x * 10 + s - '0';
return x * f;
}
void pushup(int rt)
{
e[rt].z = e[ls].z | e[rs].z;
}
void pushdown(int rt)
{
if (e[rt].lazy)
{
e[ls].clear();
e[rs].clear();
e[ls].color(e[rt].lazy);
e[rs].color(e[rt].lazy);
e[ls].lazy = e[rt].lazy;
e[rs].lazy = e[rt].lazy;
e[rt].lazy = 0;
}
}
void build(int l, int r, int rt)
{
e[rt].l = l, e[rt].r = r;
if (l == r)
{
e[rt].color(w[a[l]]);
return;
}
int mid = (l + r) >> 1;
build(l, mid, ls);
build(mid + 1, r, rs);
pushup(rt);
}
void update(int L, int R, int k, int rt)
{
if (L <= e[rt].l && e[rt].r <= R)
{
e[rt].clear();
e[rt].color(k);
e[rt].lazy = k;
return;
}
pushdown(rt);
int mid = (e[rt].l + e[rt].r) >> 1;
if (L <= mid) update(L, R, k, ls);
if (R > mid) update(L, R, k, rs);
pushup(rt);
}
ll query(int L, int R, int rt)
{
if (L <= e[rt].l && e[rt].r <= R)
{
return e[rt].z;
}
pushdown(rt);
int mid = (e[rt].l + e[rt].r) >> 1;
ll ans = 0;
if (L <= mid) ans = ans | query(L, R, ls);
if (R > mid) ans = ans | query(L, R, rs);
pushup(rt);
return ans;
}
void debug()
{
printf("debug\n");
printf(" %d\n", count(e[1].z));
printf(" %d %d\n", count(e[2].z), count(e[3].z) );
printf(" %d %d %d %d\n", count(e[4].z), count(e[5].z), count(e[6].z), count(e[7].z) );
printf(" %d %d %d %d %d %d %d %d\n", count(e[8].z),
count(e[9].z), count(e[10].z), count(e[11].z), count(e[12].z), count(e[13].z), count(e[14].z), count(e[15].z));
}
int js;
void dfs(int u, int f)
{
a[++js] = u;
begin_[u] = js;
for (int i = head[u]; i; i = edge[i].nxt)
{
int v = edge[i].v;
if (v == f) continue;
dfs(v, u);
}
end_[u] = js;
}
int main()
{
n = read(), m = read();
for (int i = 1; i <= n; ++i)
{
w[i] = read();
}
for (int i = 1; i < n; ++i)
{
int x = read(), y = read();
add_edge(x, y);
add_edge(y, x);
}
dfs(1, 0);
// cout << js << "\n";
// for (int i = 1; i <= n; ++i)
// {
// printf("%d ", a[i]);
// } puts("");
// for (int i = 1; i <= n; ++i)
// {
// printf("%d => %d~~%d\n", i, begin_[i], end_[i]);
// }
build(1, n, 1);
for (int i = 1; i <= m; ++i)
{
int tmp = read();
if (tmp == 1)
{
int a = read(), b = read();
update(begin_[a], end_[a], b, 1);
}
else
{
int a = read();
ll ans = query(begin_[a], end_[a], 1);
printf("%d\n", count(ans));
}
//debug();
}
return 0;
}
CF620E New Year Tree 线段树 dfs序的更多相关文章
- CF620E New Year Tree 线段树+dfs序+bitset
线段树维护 dfs 序是显然的. 暴力建 60 个线段树太慢,于是用 bitset 优化就好了 ~ code: #include <bits/stdc++.h> #define M 63 ...
- S - Query on a tree HDU - 3804 线段树+dfs序
S - Query on a tree HDU - 3804 离散化+权值线段树 题目大意:给你一棵树,让你求这棵树上询问的点到根节点直接最大小于等于val的长度. 这个题目和之前写的那个给你一棵 ...
- Tsinsen A1505. 树(张闻涛) 倍增LCA,可持久化线段树,DFS序
题目:http://www.tsinsen.com/A1505 A1505. 树(张闻涛) 时间限制:1.0s 内存限制:512.0MB 总提交次数:196 AC次数:65 平均分: ...
- 【XSY2534】【BZOJ4817】树点涂色 LCT 倍增 线段树 dfs序
题目大意 Bob有一棵\(n\)个点的有根树,其中\(1\)号点是根节点.Bob在每个点上涂了颜色,并且每个点上的颜色不同.定义一条路径的权值是:这条路径上的点(包括起点和终点)共有多少种不同的颜 ...
- BZOJ_3252_攻略_线段树+dfs序
BZOJ_3252_攻略_线段树+dfs序 Description 题目简述:树版[k取方格数] 众所周知,桂木桂马是攻略之神,开启攻略之神模式后,他可以同时攻略k部游戏.今天他得到了一款新游戏< ...
- 【bzoj4817】树点涂色 LCT+线段树+dfs序
Description Bob有一棵n个点的有根树,其中1号点是根节点.Bob在每个点上涂了颜色,并且每个点上的颜色不同.定义一条路 径的权值是:这条路径上的点(包括起点和终点)共有多少种不同的颜色. ...
- HDU 5692 线段树+dfs序
Snacks Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Sub ...
- 线段树+Dfs序【CF620E】New Year Tree
Description 你有一棵以1为根的有根树,有n个点,每个节点初始有一个颜色c[i]. 有两种操作: 1 v c 将以v为根的子树中所有点颜色更改为c 2 v 查询以v为根的子树中的节点有多少种 ...
- CF620E New Year Tree(树形+dfs序+线段树+状态压缩)
题目链接 题目大意 \(~~\)给出一棵 nn 个节点的树,根节点为 11.每个节点上有一种颜色 c\(_{i}\) 和m 次操作.操作有两种: \(~~~~\) 1. 1\(~\)u\(~\)c:将 ...
随机推荐
- Word文档中的格式标记大全
在Word中有很多的格式设置,很多格式设置都会有一些标记,这些标记是隐藏的,在打印文档时是不会打印出来的,但是它们却起着结构化文档的大作用.如果你在编辑文档,不妨点击格式标记开关,看看都有哪些格式标记 ...
- 异步通信----WebSocket
什么是WebSocket? WebSocket API是下一代客户端-服务器的异步通信方法.该通信取代了单个的TCP套接字,使用ws或wss协议,可用于任意的客户端和服务器程序.WebSocket目前 ...
- mvc debug无法进入controller
可能原因为,工程更改名称 进入工程bin目录下,删除所有文件即可
- ListView and gridview常用属性
刷新:notifyDataSetChanged 1.gridview常用属性 GridView的一些特殊属性: 1.Android:numColumns=”auto_fit” //GridVi ...
- 使用Lotus Enterprise Integrator (LEI)将Domino附件移至关系数据库(图文过程)
参考IBM解决方案:http://www.ibm.com/developerworks/cn/lotus/LEI-attachments/index.html 转载请注明出处:http://blog. ...
- Vue 数据绑定语法
数据绑定语法 Vue.js 的模板是基于 DOM 实现的.这意味着所有的 Vue.js 模板都是可解析的有效的 HTML,且通过一些特殊的特性做了增强.Vue 模板因而从根本上不同于基于字符串的模板, ...
- (转)Mysql 多表查询详解
MySQL 多表查询详解 一.前言 二.示例 三.注意事项 一.前言 上篇讲到mysql中关键字执行的顺序,只涉及了一张表:实际应用大部分情况下,查询语句都会涉及到多张表格 : 1.1 多表连接有 ...
- POJ1062:昂贵的聘礼(枚举+迪杰斯特拉)
http://poj.org/problem?id=1062 Description 年轻的探险家来到了一个印第安部落里.在那里他和酋长的女儿相爱了,于是便向酋长去求亲.酋长要他用10000个金币作为 ...
- POJ:2528(Mayor's posters)离散化成段更新+简单哈希
http://poj.org/problem?id=2528 Description The citizens of Bytetown, AB, could not stand that the ca ...
- 畅通工程&&How Many Tables
http://acm.hdu.edu.cn/showproblem.php?pid=1232 #include <iostream> #include <stdio.h> #i ...