[SDOI2011]染色

题目描述

输入输出格式



输出格式:

对于每个询问操作,输出一行答案。

解法

ps:这题本来是树剖的,但我用lct写的,以下是lct的写法,树剖会有所不同

我们考虑把连接不同色点的边权值设为1,连接同色的点的边权设为0,这样我们就可以把问题转化为查询这条路径上所有的边权和,你要输出的就是这个答案加一。

对于维护,我们对每条路径维护一个最左端点的值和最右端点的值,这样就可以统计O(1)地合并信息,修改时做一个懒标记,下放时将当前ans清零再修改左右端点即可。

区间反转时左右端点也要反转

区间反转时左右端点也要反转

区间反转时左右端点也要反转

重要的话说三遍(我就被坑了好久)。

代码

#include<bits/stdc++.h>
#define rg register
using namespace std;
int gi(){
char a=getchar();int b=0;
while(a<'0'||a>'9')a=getchar();
while(a>='0'&&a<='9')b=b*10+a-'0',a=getchar();
return b;
}
const int N=1e6;
int fa[N],ch[N][2],ans[N],w[N],l[N],r[N],lazy1[N],lazy2[N],fz[N],top;
int get(int x){return ch[fa[x]][1]==x;}
int isroot(int x){return ch[fa[x]][0]!=x&&ch[fa[x]][1]!=x;}
void pushdown(int x){
rg int L=ch[x][0],R=ch[x][1];
if(lazy1[x]){
swap(ch[x][0],ch[x][1]);
swap(l[L],r[L]);
swap(l[R],r[R]);
lazy1[L]^=1;
lazy1[R]^=1;
lazy1[x]^=1;
}
if(lazy2[x]){
w[x]=l[x]=r[x]=lazy2[L]=lazy2[R]=lazy2[x];
lazy2[x]=0;
ans[x]=0;
}
}
void pushup(int x){
pushdown(ch[x][0]);
pushdown(ch[x][1]);
ans[x]=0;
if(ch[x][0]){
l[x]=l[ch[x][0]];
if(w[x]!=r[ch[x][0]])ans[x]++;
}
else l[x]=w[x];
if(ch[x][1]){
r[x]=r[ch[x][1]];
if(w[x]!=l[ch[x][1]])ans[x]++;
}
else r[x]=w[x];
ans[x]+=ans[ch[x][0]]+ans[ch[x][1]];
}
void rotate(int x){
int y=fa[x],z=fa[y],k=get(x);
fa[x]=z;if(!isroot(y))ch[z][ch[z][1]==y]=x;
ch[y][k]=ch[x][k^1];fa[ch[y][k]]=y;
fa[y]=x;ch[x][k^1]=y;
pushup(y);pushup(x);
}
void splay(int x){
for(int i=x;;i=fa[i]){
fz[++top]=i;
if(isroot(i))break;
}
while(top){pushdown(fz[top--]);}
while(!isroot(x)){
int y=fa[x];
if(!isroot(y))
if(get(x)==get(y))rotate(y);
else rotate(x);
rotate(x);
}
}
void access(int x){for(int y=0;x;y=x,x=fa[x])splay(x),ch[x][1]=y,pushup(x);}
void makeroot(int x){access(x);splay(x);lazy1[x]^=1;}
void link(int x,int y){makeroot(x);fa[x]=y;}
void split(int x,int y){makeroot(x);access(y);splay(y);}
void update(int x,int y,int k){split(x,y);lazy2[y]=k;}
void query(int x,int y){split(x,y);printf("%d\n",ans[y]+1);}
int main(){
int n=gi(),m=gi();
for(int i=1;i<=n;++i){
w[i]=gi();
l[i]=r[i]=w[i];
}
for(int i=1;i<n;++i){
int x=gi(),y=gi();
link(x,y);
}
while(m--){
char op=getchar();
while(op!='C'&&op!='Q')op=getchar();
if(op=='C'){
int x=gi(),y=gi(),k=gi();
update(x,y,k);
}
if(op=='Q'){
int x=gi(),y=gi();
query(x,y);
}
}
return 0;
}

[SDOI2011]染色的更多相关文章

  1. BZOJ 2243: [SDOI2011]染色 [树链剖分]

    2243: [SDOI2011]染色 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 6651  Solved: 2432[Submit][Status ...

  2. bzoj-2243 2243: [SDOI2011]染色(树链剖分)

    题目链接: 2243: [SDOI2011]染色 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 6267  Solved: 2291 Descript ...

  3. 【BZOJ2243】[SDOI2011]染色 树链剖分+线段树

    [BZOJ2243][SDOI2011]染色 Description 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询问节点a到节点b路径上的 ...

  4. bzoj2243:[SDOI2011]染色

    链剖就可以了.一开始的想法错了.但也非常接近了.妈呀调的要死...然后把字体再缩小一号查错起来比较容易QAQ. #include<cstdio> #include<cstring&g ...

  5. bzoj 2243 [SDOI2011]染色(树链剖分,线段树)

    2243: [SDOI2011]染色 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 4637  Solved: 1726[Submit][Status ...

  6. Bzoj 2243: [SDOI2011]染色 树链剖分,LCT,动态树

    2243: [SDOI2011]染色 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 5020  Solved: 1872[Submit][Status ...

  7. 2243: [SDOI2011]染色

    2243: [SDOI2011]染色 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 3113  Solved: 1204[Submit][Status ...

  8. bzoj 2243 [SDOI2011]染色(树链剖分+线段树合并)

    [bzoj2243][SDOI2011]染色 2017年10月20日 Description 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询 ...

  9. bzoj2243[SDOI2011]染色 树链剖分+线段树

    2243: [SDOI2011]染色 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 9012  Solved: 3375[Submit][Status ...

随机推荐

  1. CAN控制器-配置过滤器

    首先简单介绍一下CAN总线,关于CAN总线是谁发明的,CAN总线的历史,CAN总线的发展,CAN总线的应用场合,这些,通通不说.这里只是以我个人理解,简单说说CAN通信.CAN总线的端点没有地址(除非 ...

  2. Java循环和条件

    下列程序的输出结果是什么? 1.Java循环和条件 /** * @Title:IuputData.java * @Package:com.you.data * @Description:TODO * ...

  3. Deadlock found when trying to get lock; try restarting transaction

    1.错误描述 [ERROR:]2015-06-09 16:56:19,481 [抄送失败] org.hibernate.exception.LockAcquisitionException: erro ...

  4. Flash Builder4破解步骤

    Flash Builder4破解步骤 1.安装Flash Builder4.0试用版 2.找到Flash Builder4的安装路径,查找如下相应的文件 3.修改如下文件下的文件 (1)找到Adobe ...

  5. 真实场景的虚拟视点合成(View Synthsis)详解

    上一篇博客中介绍了从拍摄图像到获取视差图以及深度图的过程,现在开始介绍利用视差图或者深度图进行虚拟视点的合成.虚拟视点合成是指利用已知的参考相机拍摄的图像合成出参考相机之间的虚拟相机位置拍摄的图像,能 ...

  6. 新建.Net Core应用程序后引用项一直黄色感叹号怎么办?

    我们在vs中创建.Net Core应用程序后,引用项可能出现黄色感叹号,正常情况下,这种黄色感叹号时能在项目创建成功之后迅速消失的,可也有些时候一直不消失,怎么办? 我们可以选中异常的项目,然后右键菜 ...

  7. Entity Framework Core必须牢记的三条引用三条命令

    关于EntityFramework Core有三个重要的引用和三条重要的命令,掌握以这六条,基本用Entity Framework Core就得心应手了. 引用1:Install-PackageMic ...

  8. 在.Net Core中使用MongoDB的入门教程(二)

    在上一篇文章中,讲到了MongoDB在导入驱动.MongoDB的连接,数据的插入等. 在.Net Core中使用MongoDB的入门教程(一) 本篇文章将接着上篇文章进行介绍MongoDB在.Net ...

  9. JavaScript设计模式(5)-组合模式

    组合模式 1. 适合使用组合模式的条件: 存在一批组织成某种层次体系的对象,如树形结构(具体的结构在开发期间可能无法得知) 希望对这批对象或其中的一部分对象实施一个相同的操作 2. 注意点: 组合对象 ...

  10. Html行内元素和块级元素

    1.关于行内元素和块状元素的说明 根据CSS规范的规定,每一个网页元素都有一个display属性,用于确定该元素的类型,每一个元素都有默认的display属性值,比如div元素,它的默认display ...