bzoj2243: [SDOI2011]染色--线段树+树链剖分
此题代码量较大。。但是打起来很爽
原本不用lca做一直wa不知道为什么。。
后来改lca重打了一遍= =结果一遍就AC了orz
题目比较裸,也挺容易打,主要是因为思路可以比较清晰
另:加读入优化比没加快了1.3s。。
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
;
struct node{
int l,r,lc,rc,sum,lz;
}t[maxn*];
struct edge{
int to,next;
}e[maxn*];
;
],size[maxn],col[maxn];
inline void read(int &x){
; ;
; cc=getchar();}
+cc-',cc=getchar(); x*=f;
}
inline void insert(int u, int v){
e[++tot].to=v; e[tot].next=head[u]; head[u]=tot;
}
inline void dfs1(int u, int f, int d){
size[u]=; fa[u][]=f; dep[u]=d;
; i<=logn; i++) fa[u][i]=fa[fa[u][i-]][i-];
; i=e[i].next){
int v=e[i].to;
if (v==f) continue;
dfs1(v,u,d+);
size[u]+=size[v];
if (!son[u] || size[v]>size[son[u]]) son[u]=v;
}
}
inline void dfs2(int u, int num){
top[u]=num; tree[u]=++cnt;
pre[cnt]=u;
if (!son[u]) return;
dfs2(son[u],num);
; i=e[i].next)
] && e[i].to!=son[u])
dfs2(e[i].to,e[i].to);
}
inline int lca(int u, int v){
if (dep[u]>dep[v]) swap(u,v);
while (dep[u]<dep[v]){
; i--)
if (dep[u]<dep[fa[v][i]])
v=fa[v][i];
v=fa[v][];
}
if (u==v) return u;
; i--)
if (fa[u][i]!=fa[v][i]){
u=fa[u][i];
v=fa[v][i];
}
u=fa[u][];
return u;
}
inline void pushdown(int x){
if (t[x].lz){
t[x<<].lz=t[x<<|].lz=t[x].lz;
t[x<<].lc=t[x<<].rc=t[x<<|].lc=t[x<<|].rc=t[x].lz;
t[x<<].sum=t[x<<|].sum=;
t[x].lz=;
}
}
inline void pushup(int x){
t[x].lc=t[x<<].lc; t[x].rc=t[x<<|].rc;
t[x].sum=t[x<<].sum+t[x<<|].sum-(t[x<<].rc==t[x<<|].lc);
}
inline int query(int a, int b, int x){
int l=t[x].l, r=t[x].r;
if (a==l && r==b) return t[x].sum;
;
pushdown(x);
);
|);
)+query(mid+,b,x<<|)-(t[x<<].rc==t[x<<|].lc);
}
inline void update(int a, int b, int c, int x){
int l=t[x].l, r=t[x].r;
if (a==l && r==b){
t[x].lc=t[x].rc=t[x].lz=c;
t[x].sum=;
return;
}
;
pushdown(x);
);
|);
else{
update(a,mid,c,x<<);
update(mid+,b,c,x<<|);
}
pushup(x);
}
inline int get_col(int a, int x){
int l=t[x].l, r=t[x].r;
if (l==r) return t[x].lc;
pushdown(x);
;
);
|);
}
inline void build(int l, int r, int x){
t[x].l=l; t[x].r=r;
if (l==r){
t[x].lc=t[x].rc=col[pre[l]];
t[x].sum=;
return;
}
;
);
,r,x<<|);
pushup(x);
}
inline void change(int x, int f, int c){
while (top[x]!=top[f]){
update(tree[top[x]],tree[x],c,);
x=fa[top[x]][];
}
update(tree[f],tree[x],c,);
}
inline int get_sum(int x, int f){
;
while (top[x]!=top[f]){
res+=query(tree[top[x]],tree[x],);
)==get_col(tree[fa[top[x]][]],)) res--;
x=fa[top[x]][];
}
res+=query(tree[f],tree[x],);
return res;
}
int main(){
read(n); read(m);
<<logn)<n) logn++;
; i<=n; i++) read(col[i]),col[i]++;
tot=-; memset(head,-,sizeof(head));
; i<n; i++){
read(u); read(v);
insert(u,v); insert(v,u);
}
cnt=;
dfs1(,,); dfs2(,);
build(,n,);
];
while (m--){
scanf("%s", s);
]=='Q'){
read(u); read(v);
int t=lca(u,v);
printf();
}
else{
int color;
read(u); read(v); read(color);
int t=lca(u,v);
color++;
change(u,t,color);
change(v,t,color);
}
}
;
}
bzoj2243: [SDOI2011]染色--线段树+树链剖分的更多相关文章
- [BZOJ2243][SDOI2011]染色 解题报告|树链剖分
Description 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询问节点a到节点b路径上的颜色段数量(连续相同颜色被认为是同一段),如“ ...
- [Bzoj2243][SDOI2011]染色(线段树&&树剖||LCT)
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=2243 线段树+树链剖分,在线段树需要每次用lt和rt两个数组记录当前区间的左右边界的颜色 ...
- BZOJ2243 SDOI2011 染色 【树链剖分】
BZOJ2243 SDOI2011 染色 Description 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询问节点a到节点b路径上的颜色 ...
- bzoj2243[SDOI2011]染色 树链剖分+线段树
2243: [SDOI2011]染色 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 9012 Solved: 3375[Submit][Status ...
- BZOJ2243 [SDOI2011]染色(树链剖分+线段树合并)
题目链接 BZOJ2243 树链剖分 $+$ 线段树 线段树每个节点维护$lc$, $rc$, $s$ $lc$代表该区间的最左端的颜色,$rc$代表该区间的最右端的颜色 $s$代表该区间的所有连续颜 ...
- bzoj 2243: [SDOI2011]染色 线段树区间合并+树链剖分
2243: [SDOI2011]染色 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 7925 Solved: 2975[Submit][Status ...
- BZOJ2243: [SDOI2011]染色(树链剖分/LCT)
Description 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询问节点a到节点b路径上的颜色段数量(连续相同颜色被认为是同一段), 如 ...
- 【树链剖分】bzoj2243 [SDOI2011]染色
树链剖分模板题.线段树维护每个段中的颜色数.左端点颜色.右端点颜色. pushup: col[rt]=col[rt<<1]+col[rt<<1|1]-(Rcol[rt<& ...
- [BZOJ2243][SDOI2011]染色(树链剖分)
[传送门] 树链剖分就行了,注意线段树上颜色的合并 Code #include <cstdio> #include <algorithm> #define N 100010 # ...
随机推荐
- 将十六进制色值转换成Color
在给Background赋值时,除了自带的Red,Blue,Black等,可以通过以下方法赋予其他颜色. 主要是将Hex转换成ARGB(A:alpha,表示透明度.R:Red.G:Green.B:Bl ...
- PHP文件包含漏洞攻防实战(allow_url_fopen、open_basedir)
摘要 PHP是一种非常流行的Web开发语言,互联网上的许多Web应用都是利用PHP开发的.而在利用PHP开发的Web应用中,PHP文件包含漏洞是一种常见的漏洞.利用PHP文件包含漏洞入侵网站也是主流的 ...
- JS正则检测密码强度
今天遇到个需求,使用JS检测密码强度:密码长度最短为8,必须同时包含字母.数字.特殊符号. 代码如下: /* * 检测密码复杂度 */ function ...
- r-cnn学习(八):minibatch
这段代码包括由输入图片随机生成相应的RoIs,并生成相应的blobs,由roidb得到相应的 minibatch.其代码如下. # ---------------------------------- ...
- JavaScript——理解闭包及作用
js是一个函数级语言,变量的作用域是: 内部可以访问内部,内部可以访问外部,外部不能访问内部. 如果要在外部,访问函数内部的变量,就要用到闭包.闭包就是指访问到了本不该访问的变量. 闭包作用1:实现封 ...
- 定时刷新之setTimeout(只一次)和setInterval(间隔相同时间)的使用
setTimeout和setInterval的使用 这两个方法都可以用来实现在一个固定时间段之后去执行JavaScript.不过两者各有各的应用场景. 方 法 实际上,setTimeout和setIn ...
- android 图片缓存
一.Picasso https://github.com/square/picasso Picasso是Square公司开源的一个Android平台上的图片加载框架,简单易用,一句话搞定项目中的图片加 ...
- JS和JQuery的总结
JS部分 一, 词法结构 区分大小 注意://单行 /*多行注释*/ 字面量(直接量literal) 12 // 数字 5.8//小数 "hello" 'hello' true ...
- sqlserver2000 数据库 'tempdb' 的日志已满
方法一解决过程: 查看了下数据库的属性,是自动增长,不指定文件大小上限.在网上Google了很久,试了些方法都不行:数据库所在磁盘还有很大的可用空间,试着下重药了.直接把tempdb的数据文件和日志文 ...
- 教你几种在SQLServer中删除重复数据方法(转)
转载地址:http://www.jb51.net/article/22980.htm 方法一 复制代码 代码如下: declare @max integer,@id integer declare c ...