此题代码量较大。。但是打起来很爽

原本不用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]染色--线段树+树链剖分的更多相关文章

  1. [BZOJ2243][SDOI2011]染色 解题报告|树链剖分

    Description 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询问节点a到节点b路径上的颜色段数量(连续相同颜色被认为是同一段),如“ ...

  2. [Bzoj2243][SDOI2011]染色(线段树&&树剖||LCT)

    题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=2243 线段树+树链剖分,在线段树需要每次用lt和rt两个数组记录当前区间的左右边界的颜色 ...

  3. BZOJ2243 SDOI2011 染色 【树链剖分】

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

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

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

  5. BZOJ2243 [SDOI2011]染色(树链剖分+线段树合并)

    题目链接 BZOJ2243 树链剖分 $+$ 线段树 线段树每个节点维护$lc$, $rc$, $s$ $lc$代表该区间的最左端的颜色,$rc$代表该区间的最右端的颜色 $s$代表该区间的所有连续颜 ...

  6. bzoj 2243: [SDOI2011]染色 线段树区间合并+树链剖分

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

  7. BZOJ2243: [SDOI2011]染色(树链剖分/LCT)

    Description 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询问节点a到节点b路径上的颜色段数量(连续相同颜色被认为是同一段), 如 ...

  8. 【树链剖分】bzoj2243 [SDOI2011]染色

    树链剖分模板题.线段树维护每个段中的颜色数.左端点颜色.右端点颜色. pushup: col[rt]=col[rt<<1]+col[rt<<1|1]-(Rcol[rt<& ...

  9. [BZOJ2243][SDOI2011]染色(树链剖分)

    [传送门] 树链剖分就行了,注意线段树上颜色的合并 Code #include <cstdio> #include <algorithm> #define N 100010 # ...

随机推荐

  1. Coursera-Getting and Cleaning Data-week4-R语言中的正则表达式以及文本处理

    博客总目录:http://www.cnblogs.com/weibaar/p/4507801.html Thursday, January 29, 2015 补上第四周笔记,以及本次课程总结. 第四周 ...

  2. 【bzoj1076】[SCOI2008]奖励关

    题目描述 你正在玩你最喜欢的电子游戏,并且刚刚进入一个奖励关.在这个奖励关里,系统将依次随机抛出k次宝物,每次你都可以选择吃或者不吃(必须在抛出下一个宝物之前做出选择,且现在决定不吃的宝物以后也不能再 ...

  3. svn清除已保存的用户名和密码

    在项目中使用SVN是必须的,我们一般将用户名和密码进行保存处理,这样做的好处在于每次都不用输入了,方便快捷.但是当我们想用另外一个svn账号时,这时候该怎么办呢,看下图,让提示框重新出来. 找到这个页 ...

  4. Linux进程间通信(一): 信号 signal()、sigaction()

    一.什么是信号 用过Windows的我们都知道,当我们无法正常结束一个程序时,可以用任务管理器强制结束这个进程,但这其实是怎么实现的呢?同样的功能在Linux上是通过生成信号和捕获信号来实现的,运行中 ...

  5. java笔记--关于线程同步(7种同步方式)

    关于线程同步(7种方式) --如果朋友您想转载本文章请注明转载地址"http://www.cnblogs.com/XHJT/p/3897440.html"谢谢-- 为何要使用同步? ...

  6. Java NIO工作原理

    数据通信流程: 通过selector.select()阻塞方法获取到感兴趣事件的key,根据key定位到channel,通过channel的读写操作进行数据通信.channel的read或者write ...

  7. MySQL分库分表的一些技巧

    分表是分散数据库压力的好方法. 分表,最直白的意思,就是将一个表结构分为多个表,然后,可以再同一个库里,也可以放到不同的库. 当然,首先要知道什么情况下,才需要分表.个人觉得单表记录条数达到百万到千万 ...

  8. Linq查询表达式

    目录 1. 概述 2. from子句 3. where子句 4. select子句 5. group子句 6. into子句 7. 排序子句 8. let子句 9. join子句 10. 小结 1. ...

  9. server2003中看不到网上邻居内容,其他电脑无法通过计算机名和IP访问本计算机(但网上邻居中可访问到)

    现象1:server2003中看不到网上邻居内容,查看工作组计算机看到的是空列表, 现象2:其他电脑无法通过计算机名和IP访问本计算机(但网上邻居中可访问到)   访问提示:--Windows 200 ...

  10. mac在终端下中用sublime text 2 打开文件

    alias subl=\''/Applications/Sublime Text 2.app/Contents/SharedSupport/bin/subl'\'然后subl 要打开的文件名即可但是这 ...