亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Bzoj 2243: [SDOI2011]染色(樹鏈剖分+線段樹)

2019-11-14 13:13:56
字體:
來源:轉載
供稿:網友

2243: [SDOI2011]染色 Time Limit: 20 Sec Memory Limit: 512 MB Description 給定一棵有n個節點的無根樹和m個操作,操作有2類: 1、將節點a到節點b路徑上所有點都染成顏色c; 2、詢問節點a到節點b路徑上的顏色段數量(連續相同顏色被認為是同一段),如“112221”由3段組成:“11”、“222”和“1”。 請你寫一個程序依次完成這m個操作。 Input 第一行包含2個整數n和m,分別表示節點數和操作數; 第二行包含n個正整數表示n個節點的初始顏色 下面 行每行包含兩個整數x和y,表示x和y之間有一條無向邊。 下面 行每行描述一個操作: “C a b c”表示這是一個染色操作,把節點a到節點b路徑上所有點(包括a和b)都染成顏色c; “Q a b”表示這是一個詢問操作,詢問節點a到節點b(包括a和b)路徑上的顏色段數量。 Output 對于每個詢問操作,輸出一行答案。 Sample Input 6 5 2 2 1 2 1 1 1 2 1 3 2 4 2 5 2 6 Q 3 5 C 2 1 1 Q 3 5 C 5 1 2 Q 3 5 Sample Output 3 1 2 HINT 數N<=10^5,操作數M<=10^5,所有的顏色C為整數且在[0, 10^9]之間。 Source 第一輪day1

/*樹鏈剖分+線段樹.讀入操作的時候要用ch[2] scanf 讀入(又被卡了).這還是shenben告訴我的%%%.以為用樹剖搞貢獻可能無法處理銜接點.然后就yy了一種類似于暴力的做法.倍增處理出lca然后跳鏈.一開始只能得70分不知道為啥(寫的很鬼畜~).原來是沒寫lca是鏈頂的情況.網上大多數人的做法是處理區間貢獻然后單點查詢判斷端點情況,一開始因為想到找鏈的時候兩個點蹦跶可能不好處理端點然后就沒這樣搞...其實我們可以先處理出段點的貢獻(還是有點暈~). 通過這題還會了手動開棧.我是找的lca然后分情況討論亂搞.這題線段樹merge什么的都還好.還有幾個需要注意的地方:build tree 標號,update &&pushtag.最重要的是讀入讀入讀入?。?!*/#include<iostream>#include<cstdio>#include<algorithm>#define MAXN 100001using namespace std;struct data{int l,r,lc,rc,sum,lans,rans,bj;}tree[MAXN<<2];struct edge{int v,next;}e[MAXN*2];int n,m,cut,head[MAXN],a[MAXN];int maxsize,size[MAXN],pos[MAXN],top[MAXN],deep[MAXN],fa[MAXN][25];int read(){ int x=0,f=1;char ch=getchar(); while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();} while(ch>='0'&&ch<='9') x=x*10+ch-48,ch=getchar(); return x*f;}void add(int u,int v){ e[++cut].v=v; e[cut].next=head[u]; head[u]=cut;}void update(int k){ if(tree[tree[k].lc].rans==tree[tree[k].rc].lans) tree[k].sum=tree[tree[k].lc].sum+tree[tree[k].rc].sum-1; else tree[k].sum=tree[tree[k].lc].sum+tree[tree[k].rc].sum; tree[k].lans=tree[tree[k].lc].lans;tree[k].rans=tree[tree[k].rc].rans; return ;}void push(int k){ tree[tree[k].lc].bj=tree[tree[k].rc].bj=tree[k].bj; tree[tree[k].lc].lans=tree[tree[k].lc].rans=tree[k].bj; tree[tree[k].rc].lans=tree[tree[k].rc].rans=tree[k].bj; tree[tree[k].lc].sum=tree[tree[k].rc].sum=1; tree[k].bj=0; return ;}void build(int l,int r){ int k=++cut;tree[k].l=l,tree[k].r=r; if(l==r) return ;// 1w. int mid=(l+r)>>1; tree[k].lc=cut+1;build(l,mid); tree[k].rc=cut+1;build(mid+1,r); update(k);return ;}void change(int k,int l,int r,int z){ if(l<=tree[k].l&&tree[k].r<=r) { tree[k].sum=1; tree[k].lans=tree[k].rans=z; tree[k].bj=z; return ; } if(tree[k].bj) push(k); int mid=(tree[k].l+tree[k].r)>>1; if(l<=mid) change(tree[k].lc,l,r,z); if(r>mid) change(tree[k].rc,l,r,z); update(k);//2w. return ;}data query(int k,int l,int r){ data xx; if(l<=tree[k].l&&tree[k].r<=r) return tree[k]; if(tree[k].bj) push(k); int mid=(tree[k].l+tree[k].r)>>1; if(l>mid) return query(tree[k].rc,l,r); else if(r<=mid) return query(tree[k].lc,l,r); else { data ll=query(tree[k].lc,l,mid); data rr=query(tree[k].rc,mid+1,r); if(ll.rans==rr.lans) xx.sum=ll.sum+rr.sum-1; else xx.sum=ll.sum+rr.sum; xx.lans=ll.lans,xx.rans=rr.rans; } update(k); return xx;}void dfs1(int u){ size[u]=1; for(int i=head[u];i;i=e[i].next) { int v=e[i].v; if(!fa[v][0]) fa[v][0]=u,deep[v]=deep[u]+1,dfs1(v),size[u]+=size[v]; } return ;}void dfs2(int u,int top1){ pos[u]=++maxsize;top[u]=top1; int k=0; for(int i=head[u];i;i=e[i].next) { int v=e[i].v; if(fa[v][0]==u&&size[v]>size[k]) k=v; } if(!k) return ; dfs2(k,top1); for(int i=head[u];i;i=e[i].next) { int v=e[i].v; if(fa[v][0]==u&&v!=k) dfs2(v,v); } return ;}void slovechange(int x,int y,int z){ while(top[x]!=top[y]) { if(deep[top[x]]<deep[top[y]]) swap(x,y); change(1,pos[top[x]],pos[x],z); x=fa[top[x]][0]; } if(pos[x]>pos[y]) swap(x,y); change(1,pos[x],pos[y],z); return ;}int get_same(int u,int v){ for(int i=0;i<=20;i++) if(v&(1<<i)) u=fa[u][i]; return u;}int lca(int u,int v){ if(deep[u]<deep[v]) swap(u,v); u=get_same(u,deep[u]-deep[v]); if(u==v) return u; for(int i=20;i>=0;i--) { if(fa[u][i]!=fa[v][i]) u=fa[u][i],v=fa[v][i]; } return fa[u][0];}int get(int k,int x){ if(tree[k].l==tree[k].r) return tree[k].lans; if(tree[k].bj) push(k); int mid=(tree[k].l+tree[k].r)>>1; if(x<=mid) return get(tree[k].lc,x); else return get(tree[k].rc,x); update(k);}int slovequery(int x,int y){ /*int ans=0; while(top[x]!=top[y]) { if(deep[top[x]]<deep[top[y]]) swap(x,y); ans+=query(1,pos[top[x]],pos[x]).sum; if(get(1,pos[top[x]])==get(1,pos[fa[top[x]][0]])) ans--; x=fa[top[x]][0]; } if(pos[x]>pos[y]) swap(x,y); ans+=query(1,pos[x],pos[y]).sum; return ans;*/ data ans,ansl,ansr; int lc=lca(x,y); if(top[x]==top[y]) { if(pos[x]>pos[y]) swap(x,y); ans=query(1,pos[x],pos[y]); return ans.sum; } if(deep[lc]>deep[top[x]]||lc==top[x]) ansl=query(1,pos[lc],pos[x]); else { ansl=query(1,pos[top[x]],pos[x]);x=fa[top[x]][0]; while(deep[lc]<deep[top[x]]) { ans=query(1,pos[top[x]],pos[x]); if(ans.rans==ansl.lans) ans.sum+=ansl.sum-1; else ans.sum+=ansl.sum; ans.rans=ansl.rans; ansl=ans; x=fa[top[x]][0]; } ans=query(1,min(pos[lc],pos[x]),max(pos[lc],pos[x])); if(ans.rans==ansl.lans) ans.sum+=ansl.sum-1; else ans.sum+=ansl.sum; ans.rans=ansl.rans; ansl=ans; } if(deep[lc]>deep[top[y]]||lc==top[y]) ansr=query(1,pos[lc],pos[y]); else { ansr=query(1,pos[top[y]],pos[y]);y=fa[top[y]][0]; while(deep[lc]<deep[top[y]]) { ans=query(1,pos[top[y]],pos[y]); if(ans.rans==ansr.lans) ans.sum+=ansr.sum-1; else ans.sum+=ansr.sum; ans.rans=ansr.rans; ansr=ans; y=fa[top[y]][0]; } ans=query(1,min(pos[y],pos[lc]),max(pos[lc],pos[y])); if(ans.rans==ansr.lans) ans.sum+=ansr.sum-1; else ans.sum+=ansr.sum; ans.rans=ansr.rans; ansr=ans; } if(ansl.lans==ansr.lans) ans.sum=ansl.sum+ansr.sum-1; else ans.sum=ansl.sum+ansr.sum; return ans.sum;}void get_father(){ for(int j=1;j<=20;j++) for(int i=1;i<=n;i++) fa[i][j]=fa[fa[i][j-1]][j-1]; return ;}int main(){ freopen("paint.in","r",stdin); freopen("paint.out","w",stdout); /*int ss=64<<20; char *p=(char *)malloc(ss)+ss; __asm__("movl %0, %%esp/n"::"r"(p));*/ int x,y,z;char ch[2]; n=read(),m=read(); for(int i=1;i<=n;i++) a[i]=read(); for(int i=1;i<=n-1;i++) { x=read(),y=read(); add(x,y),add(y,x); } fa[1][0]=1;dfs1(1),dfs2(1,1); cut=0;build(1,n); for(int i=1;i<=n;i++) change(1,pos[i],pos[i],a[i]); get_father(); for(int i=1;i<=m;i++) { scanf("%s",ch);// n T.... if(ch[0]=='Q') x=read(),y=read(),
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品爽黄69天堂a| 一区二区三区四区视频| 九九久久久久久久久激情| 久久av红桃一区二区小说| 亚洲国产成人精品女人久久久| 两个人的视频www国产精品| 久久五月天色综合| 欧美性生活大片免费观看网址| 精品动漫一区二区| 国产综合色香蕉精品| 日韩欧美成人区| 91久久久久久久久久| 久久精品久久久久久| 日韩av在线高清| 欧美成人高清视频| 国产欧美日韩亚洲精品| 亚洲视频在线观看| 欧美精品激情在线| 欧美黄色免费网站| 欧美精品久久久久久久久| 国产精品久久久久国产a级| 亚洲国产97在线精品一区| 亚洲成人激情在线观看| 在线丨暗呦小u女国产精品| 午夜精品久久久久久99热软件| 国产精品久久久久不卡| 色综久久综合桃花网| 亚洲第一黄色网| 中文字幕亚洲欧美在线| 国产精品美女在线观看| 精品视频在线观看日韩| 亚洲精品天天看| 亚洲男女自偷自拍图片另类| 国产在线久久久| 2019中文字幕在线免费观看| 欧美性感美女h网站在线观看免费| 亚洲国产精品小视频| 国产精品福利小视频| 亚洲视频777| 91精品国产自产91精品| 久久精品精品电影网| 欧美精品在线免费播放| 欧美国产精品人人做人人爱| 久久精品人人做人人爽| 在线性视频日韩欧美| 亚洲国产精品va在线看黑人动漫| 欧美日韩在线免费观看| 亚洲精品久久久久久下一站| 欧美大片在线看免费观看| 欧美激情综合色| 日本久久亚洲电影| 麻豆国产va免费精品高清在线| 日韩欧美一区二区在线| 欧美性生交大片免网| 日韩av电影免费观看高清| 国产国语刺激对白av不卡| 欧美日韩在线免费| 久久久久久成人精品| 国产亚洲成av人片在线观看桃| 午夜精品免费视频| 欧美成人第一页| 欧美在线视频一二三| 成人精品aaaa网站| 日韩免费在线视频| 国产成人精品日本亚洲专区61| 欧美成人免费大片| 国产丝袜精品第一页| 亚洲黄色在线观看| 国产免费一区二区三区在线能观看| 亚洲欧美日韩天堂| 日韩视频免费观看| 欧美电影免费观看| 久久久亚洲国产天美传媒修理工| 九九热精品在线| 69久久夜色精品国产69乱青草| 91精品国产综合久久久久久蜜臀| 日韩中文字幕亚洲| 国产精品久久久久久av福利| 亚洲国产欧美一区| 91久久久精品| 人九九综合九九宗合| 欧美另类精品xxxx孕妇| 97国产一区二区精品久久呦| 日韩精品在线私人| 懂色aⅴ精品一区二区三区蜜月| 色黄久久久久久| 爽爽爽爽爽爽爽成人免费观看| 一个人看的www欧美| 国产在线播放91| 91欧美精品成人综合在线观看| 欧美日韩免费区域视频在线观看| 国产日本欧美视频| 日韩在线播放av| 欧洲s码亚洲m码精品一区| 97在线精品国自产拍中文| 日韩高清人体午夜| 久久久久久久999精品视频| 日韩中文娱乐网| 九九热在线精品视频| 成人免费视频网址| 国产日韩中文在线| 91精品在线观看视频| 成人福利网站在线观看11| 精品中文字幕在线2019| 欧美日韩亚洲高清| 日韩精品亚洲元码| 亚洲免费电影在线观看| 亚洲欧美另类人妖| 97高清免费视频| 九九热99久久久国产盗摄| 38少妇精品导航| 色综合天天狠天天透天天伊人| 久久精品国产亚洲7777| 欧美性色19p| 国产精品三级久久久久久电影| 亚洲女在线观看| 国产91精品久久久久| 伊人av综合网| 91成人福利在线| 中文字幕日本欧美| 国产久一一精品| 2025国产精品视频| 久久亚洲成人精品| 久久激情视频免费观看| 国产美女高潮久久白浆| 色99之美女主播在线视频| 91精品久久久久久久久久久| 欧美激情精品久久久久| 久久国产精品网站| 91人成网站www| 国产精品视频区| 成人精品一区二区三区电影免费| 欧美激情在线狂野欧美精品| 国产精品一香蕉国产线看观看| 日韩精品免费在线播放| 国产91免费观看| 欧美成年人视频| 亚洲自拍偷拍区| 久久国产精品偷| 亚洲va欧美va国产综合久久| 91九色精品视频| 久久久在线观看| 国模精品系列视频| 亚洲性夜色噜噜噜7777| 国产精品久久久久久久久久久久| 国产主播在线一区| 欧美国产第一页| 欧美精品久久久久| 国产精品高清网站| 精品久久中文字幕久久av| 欧美成人精品h版在线观看| 日本sm极度另类视频| 久久精品在线播放| 成人黄色av播放免费| 亚洲欧美国产高清va在线播| 精品国产一区久久久| 高清欧美电影在线| 国产精品丝袜久久久久久高清| 精品露脸国产偷人在视频| 国产成人小视频在线观看| 日韩欧美在线中文字幕| 日韩电影免费在线观看| 国产成人精品电影久久久| 国产91精品黑色丝袜高跟鞋|