【BZOJ 2243】染色 - 树链剖分+线段树
#include <cstdio>
#include <cstring>
#include <cstdlib>
using namespace std;
const int N=100001;
int n,m,color[N]; //Basic
struct G
{
int v,nxt;
}map[N+N];
int hd[N],tt; //Graph
int son[N],dep[N],pre[N],size[N];
int tid[N],top[N],num; //Chain
struct T
{
int l,r;
int lc,rc,tag;
int cnt;
}tr[N<<2]; //Segment Tree
inline int read(void)
{
int s=0,f=1; char c=getchar();
for (;c<'0'||c>'9';c=getchar()) if (c=='-') f=-1;
for (;'0'<=c&&c<='9';c=getchar()) s=(s<<1)+(s<<3)+c-'0';
return s*f;
}
inline void ins(int u,int v)
{
map[++tt].v=v;
map[tt].nxt=hd[u];
hd[u]=tt;
}
void find(int now,int ht)
{
dep[now]=ht,size[now]=1;
for (int k=hd[now];k;k=map[k].nxt)
if (!size[map[k].v])
{
find(map[k].v,ht+1);
size[now]+=size[map[k].v];
pre[map[k].v]=now;
if (!son[now]||size[son[now]]<size[map[k].v]) son[now]=map[k].v;
}
}
void cut(int now,int anc)
{
top[now]=anc,tid[now]=++num;
if (son[now]) cut(son[now],anc);
for (int k=hd[now];k;k=map[k].nxt)
if (!tid[map[k].v]) cut(map[k].v,map[k].v);
}
inline void clear(int now)
{
if (tr[now].tag==-1) return;
tr[now<<1].tag=tr[now<<1|1].tag=tr[now].tag;
tr[now<<1].lc=tr[now<<1].rc=tr[now].tag;
tr[now<<1|1].lc=tr[now<<1|1].rc=tr[now].tag;
tr[now<<1].cnt=tr[now<<1|1].cnt=1;
tr[now].tag=-1;
}
void build(int now,int l,int r)
{
tr[now].l=l;
tr[now].r=r;
tr[now].tag=-1;
if (l^r)
{
int mid=l+r>>1;
build(now<<1,l,mid);
build(now<<1|1,mid+1,r);
}
}
void ins(int now,int l,int r,int c)
{
if (l<=tr[now].l&&tr[now].r<=r)
{
tr[now].tag=tr[now].lc=tr[now].rc=c;
tr[now].cnt=1;
return;
}
clear(now);
int mid=tr[now].l+tr[now].r>>1;
if (l<=mid) ins(now<<1,l,r,c);
if (mid<r) ins(now<<1|1,l,r,c);
tr[now].lc=tr[now<<1].lc;
tr[now].rc=tr[now<<1|1].rc;
tr[now].cnt=tr[now<<1].cnt+tr[now<<1|1].cnt-(tr[now<<1].rc==tr[now<<1|1].lc);
}
void init(void)
{
n=read(),m=read();
for (int i=1;i<=n;i++) color[i]=read();
int u,v;
for (int i=1;i<n;i++)
{
u=read(),v=read();
ins(u,v),ins(v,u);
}
find(1,1);
cut(1,1);
build(1,1,n);
for (int i=1;i<=n;i++) ins(1,tid[i],tid[i],color[i]);
}
inline int LCA(int x,int y)
{
for (;top[x]^top[y];)
if (dep[top[x]]>dep[top[y]])
x=pre[top[x]];
else y=pre[top[y]];
return dep[x]<dep[y]?x:y;
}
int query(int now,int l,int r)
{
if (l<=tr[now].l&&tr[now].r<=r) return tr[now].cnt;
clear(now);
int mid=tr[now].l+tr[now].r>>1,sum=0;
if (l<=mid) sum+=query(now<<1,l,r);
if (mid<r) sum+=query(now<<1|1,l,r);
if (l<=mid&&mid<r) sum-=tr[now<<1].rc==tr[now<<1|1].lc;
return sum;
}
int findcolor(int now,int loc)
{
if (tr[now].l==tr[now].r) return tr[now].tag;
clear(now);
int mid=tr[now].l+tr[now].r>>1;
return findcolor(now<<1|(loc<=mid?0:1),loc);
}
void work(void)
{
char c; int x,y,z,p,res,uc,dc;
for (int i=1;i<=m;i++)
{
scanf("\n%c",&c);
if (c=='C')
{
x=read(),y=read(),z=read(),p=LCA(x,y);
for (;top[x]^top[p];x=pre[top[x]]) ins(1,tid[top[x]],tid[x],z);
for (;top[y]^top[p];y=pre[top[y]]) ins(1,tid[top[y]],tid[y],z);
ins(1,tid[p],x^p?tid[x]:tid[y],z);
}
else
{
x=read(),y=read(),p=LCA(x,y);
uc=dc=-1,res=0;
for (;top[x]^top[p];x=pre[top[x]])
{
if (uc^-1)
{
dc=findcolor(1,tid[x]);
res-=uc==dc;
}
res+=query(1,tid[top[x]],tid[x]);
uc=findcolor(1,tid[top[x]]);
}
dc=findcolor(1,tid[x]);
res-=uc==dc;
uc=dc=-1;
for (;top[y]^top[p];y=pre[top[y]])
{
if (uc^-1)
{
dc=findcolor(1,tid[y]);
res-=uc==dc;
}
res+=query(1,tid[top[y]],tid[y]);
uc=findcolor(1,tid[top[y]]);
}
dc=findcolor(1,tid[y]);
res-=uc==dc;
res+=query(1,tid[p],x^p?tid[x]:tid[y]);
printf("%d\n",res);
}
}
}
int main(void)
{
init();
work();
return 0;
}
【BZOJ 2243】染色 - 树链剖分+线段树的更多相关文章
- 2243: [SDOI2011]染色 树链剖分+线段树染色
给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询问节点a到节点b路径上的颜色段数量(连续相同颜色被认为是同一段), 如“112221”由3段组 ...
- bzoj2243[SDOI2011]染色 树链剖分+线段树
2243: [SDOI2011]染色 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 9012 Solved: 3375[Submit][Status ...
- 【BZOJ2243】[SDOI2011]染色 树链剖分+线段树
[BZOJ2243][SDOI2011]染色 Description 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询问节点a到节点b路径上的 ...
- B20J_2243_[SDOI2011]染色_树链剖分+线段树
B20J_2243_[SDOI2011]染色_树链剖分+线段树 一下午净调这题了,争取晚上多做几道. 题意: 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成 ...
- BZOJ.4034 [HAOI2015]树上操作 ( 点权树链剖分 线段树 )
BZOJ.4034 [HAOI2015]树上操作 ( 点权树链剖分 线段树 ) 题意分析 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 ...
- BZOJ.1036 [ZJOI2008]树的统计Count ( 点权树链剖分 线段树维护和与最值)
BZOJ.1036 [ZJOI2008]树的统计Count (树链剖分 线段树维护和与最值) 题意分析 (题目图片来自于 这里) 第一道树链剖分的题目,谈一下自己的理解. 树链剖分能解决的问题是,题目 ...
- BZOJ 3672[NOI2014]购票(树链剖分+线段树维护凸包+斜率优化) + BZOJ 2402 陶陶的难题II (树链剖分+线段树维护凸包+分数规划+斜率优化)
前言 刚开始看着两道题感觉头皮发麻,后来看看题解,发现挺好理解,只是代码有点长. BZOJ 3672[NOI2014]购票 中文题面,题意略: BZOJ 3672[NOI2014]购票 设f(i)f( ...
- bzoj 4196 [Noi2015]软件包管理器 (树链剖分+线段树)
4196: [Noi2015]软件包管理器 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 2852 Solved: 1668[Submit][Sta ...
- BZOJ2243 [SDOI2011]染色(树链剖分+线段树合并)
题目链接 BZOJ2243 树链剖分 $+$ 线段树 线段树每个节点维护$lc$, $rc$, $s$ $lc$代表该区间的最左端的颜色,$rc$代表该区间的最右端的颜色 $s$代表该区间的所有连续颜 ...
- bzoj 2157: 旅游【树链剖分+线段树】
裸的树链剖分+线段树 但是要注意一个地方--我WA了好几次才发现取完相反数之后max值和min值是要交换的-- #include<iostream> #include<cstdio& ...
随机推荐
- form 提交
1.方式1:字段加验证 @model MvcWeb.Models.UserInfo @{ ViewBag.Title = "Add"; } <h2>Add</h2 ...
- 编译android源码官方教程(5)编译完之后刷机、编译fastboot
Running Builds IN THIS DOCUMENT Building fastboot and adb Booting into fastboot mode Unlocking the b ...
- MySQL的事务
MySQL的事务 1.事务:事务是由一步或者几步数据库操作序列组成的逻辑执行单元,这一系列操作要么全部执行,要么全部放弃执行. 2.事务具备的四个特性(简称为ACID性): (1)原子性(Atomic ...
- iOS framework
(一),lipo 命令 1)合并文件: lipo -create xxxX/liblibsql.a xxxx/liblibsql.a -output libsql.a 2)查看Framework 对C ...
- 两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。已抽签决定比赛名单。有人向队员打听比赛的名单。a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。
package C; public class Bisai { public static void main(String[] args) { String a="xyz",b= ...
- 【转】VB中应用DDE
动态数据交换(dde)是windows应用程序间通讯的基本方法之一,在动态数据交换的过程中,提供数据和服务的应用程序称为服务器,请求数据或服务的应用程序则称为客户. dde交谈是由客户程序启动的.如果 ...
- oracle小测试
1.请解释以下几个函数意思:NVL.TRUNC.DECODE.TO_DTAE.TO_CHAR.CONVERT.ROUND.TRIM.ISNULL.SUBSTR.GROUP BY.HAVING 答: N ...
- [SAP ABAP开发技术总结]屏幕跳转
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- Web项目中创建简单的错误处理页面
当应用程序出现错误的时候,如果没有做错误页面处理的话,会直接输出一些敏感的信息出来,有时候甚至会直接将项目所在的物理路径给显示出来,严重缺乏安全性,并且错误种类繁多,页面风格不一,导致用户体验不好,本 ...
- STORM_0002_在做好的zookeeper集群上搭建storm的开发环境
参考文献http://www.cnblogs.com/panfeng412/archive/2012/11/30/how-to-install-and-deploy-storm-cluster.htm ...