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

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

BZOJ 2959 長跑

2019-11-10 16:58:46
字體:
來源:轉載
供稿:網友

LCT+縮邊雙+并查集

 顯然如果進入一個邊雙聯通分量,那一定能取遍所有點再出來.于是只要維護邊雙即可.對于加邊,需要縮點,用LCT即可,判斷是不是在一個邊雙里用個并查集就行.

 此題時限比較緊.注意到在縮點之后,LCT上的操基本只有access需要查詢真實父親(因為縮點之后的點單獨屬于一個分量),其他操作并不需要查并查集.把這個優化掉就能過了...?

#include<cstdio>#include<algorithm>#define N 150005#define IL inlineusing namespace std;namespace IO { char _B[1 << 26], *_S = _B; #define Begin() fread(_B, 1, 1 << 26, stdin) #define inline __inline__ __attribute__((always_inline)) inline int read() { register int x, b; for ( ; *_S < '-'; ++ _S); for (*_S != '-' ? x = *_S ++ - '0', b = 1 : (_S ++, x = b = 0); *_S >= '0'; x = (x << 3) + (x << 1) + *_S ++ - '0'); return b ? x : -x; }}namespace runzhe2000{ using namespace IO; int n, m, val[N]; struct UFS { int f[N]; int find(int x){return x == f[x] ? x : f[x] = find(f[x]);} inline void unio(int x, int y){f[find(x)] = find(y);} }s, st; struct node *tot, *null, *pos[N], *fir; struct node { node *ch[2], *fa; int sum, val, rev; IL node* F(){return pos[s.find(this - fir)];} IL node* Fa(){return fa->F() == F() ? null : fa->F();} }mem[N], *_t; node *newnode(int v) { node *p = ++tot; *p = *null; p->val = p->sum = v; return p; } void init() { pos[0] = null = tot = fir = mem; null->ch[0] = null->ch[1] = null->fa = null; null->sum = null->val = null->rev = 0; } int type(node *p){return p->fa->ch[1]==p;} bool isroot(node *p){return p != p->fa->ch[type(p)];} void pushup(node *p){p->sum = p->val + p->ch[0]->sum + p->ch[1]->sum;} void pushdown(node *p) { if(p->rev) { _t = p->ch[0], p->ch[0] = p->ch[1], p->ch[1] = _t; p->ch[0] = p->ch[0], p->ch[1] = p->ch[1]; p->ch[0]->rev ^= 1, p->ch[1]->rev ^= 1, p->rev = 0; } } void PRe(node *p){if(!isroot(p)) pre(p->Fa()); pushdown(p);} void rotate(node *p) { node *f = p->fa; int d = type(p); (p->fa = f->fa), !isroot(f) ? p->fa->ch[type(f)] = p : 0; (f->ch[d] = p->ch[!d]) != null ? p->ch[!d]->fa = f : 0; p->ch[!d] = f, f->fa = p; pushup(f); } IL void splay(node *p) { for(pre(p); !isroot(p);) { node *f = p->fa; if(isroot(f)) rotate(p); else {if(type(p) == type(f)) rotate(f); else rotate(p); rotate(p);} } pushup(p); } IL void access(node *p) { node *tmp = null; for(; p != null; p = (tmp = p)->fa) { splay(p); p->ch[1] = tmp; p->fa = p->Fa(); pushup(p); } } IL void makeroot(node *p) { access(p); splay(p); p->rev ^= 1; } IL void link(node *a, node *b) { makeroot(a); a->fa = b; } void reduc(node *a, node *b) { if(a == null) return; s.unio(a - mem, b - mem); b->val += a->val; reduc(a->ch[0], b); reduc(a->ch[1], b); a->ch[0] = a->ch[1] = null; } IL void main() { int happy = Begin(); n = read(); m = read(); init(); for(int i = 1, v; i <= n; i++) { s.f[i] = i, st.f[i] = i; pos[i] = newnode(val[i] = read()); } int op, A, B; node *pA, *pB; for(int i = 1; i <= m; i++) { op = read(), A = read(), B = read(); pA = pos[A]->F(), pB = pos[B]->F(); if(op == 1) { if(st.find(A) != st.find(B))link(pA, pB), st.unio(A, B); else { int fA = s.find(A), fB = s.find(B); if(fA != fB) { makeroot(pA); access(pB); splay(pB); reduc(pB->ch[0]->F(), pB); pushup(pB); } } } else if(op == 2) { splay(pA); pA->val += B - val[A]; pushup(pA); val[A] = B; } else { if(st.find(A) != st.find(B)) puts("-1"); else { makeroot(pA); access(pB); splay(pB); printf("%d/n",pB->sum); } } } }}int main(){ runzhe2000::main();}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕在线观看日韩| 久99九色视频在线观看| 欧美日韩国产在线看| 日韩中文字在线| 视频在线观看一区二区| 91免费国产视频| 国产精品福利无圣光在线一区| 国产精品久久久久久一区二区| 日韩电影在线观看永久视频免费网站| 精品国产福利视频| 亚洲第一视频网站| 久久成人综合视频| 亚洲性夜色噜噜噜7777| 国产成人精品久久久| 亚洲综合视频1区| 成人午夜在线视频一区| 中国china体内裑精亚洲片| 日韩不卡在线观看| 97视频在线观看免费高清完整版在线观看| 久久夜色精品国产欧美乱| 精品精品国产国产自在线| 国产日韩在线播放| 欧美交受高潮1| 国产在线久久久| 中文字幕日韩欧美在线视频| 国产精品高潮粉嫩av| 91麻豆国产精品| 久久久久久尹人网香蕉| 亚洲人成电影网站色www| 最近2019好看的中文字幕免费| 成人久久18免费网站图片| 成人激情电影一区二区| 久久精品国产久精国产一老狼| 欧美大荫蒂xxx| 夜夜嗨av一区二区三区四区| 97av视频在线| 欧美乱人伦中文字幕在线| 久久精品一本久久99精品| 国产成人精品在线播放| 热久久免费视频精品| 久久久av亚洲男天堂| 日韩专区中文字幕| 久久露脸国产精品| 久久国产视频网站| 亚洲美女在线视频| 国产在线拍揄自揄视频不卡99| 91精品国产免费久久久久久| 日韩欧美亚洲国产一区| 日韩av片电影专区| 亚洲欧美综合另类中字| 日韩中文有码在线视频| 欧美精品福利在线| 久久久精品免费视频| 精品久久中文字幕久久av| 久久精品国产清自在天天线| 91色精品视频在线| 欧美人交a欧美精品| 2019中文在线观看| 日韩av影视综合网| 亚洲精品国产精品国产自| 中文精品99久久国产香蕉| 欧美国产日韩免费| 精品亚洲男同gayvideo网站| 日韩成人性视频| 欧美电影免费观看电视剧大全| 在线观看久久av| 欧美另类老女人| 日韩精品视频在线观看网址| 亚洲精品欧美日韩| 欧美性猛交xxxx乱大交蜜桃| 亚洲精品99久久久久中文字幕| 亚洲精品98久久久久久中文字幕| 中文字幕亚洲欧美日韩高清| 欧美激情视频播放| 欧美日韩免费网站| 国产精品电影观看| 精品丝袜一区二区三区| 亚洲成人av片在线观看| 亚洲国产精品系列| 亚洲国产精品yw在线观看| 国产一区二中文字幕在线看| 色综合老司机第九色激情| 欧美一级成年大片在线观看| 97久久精品国产| 亚洲美女性生活视频| 欧美亚洲另类在线| 欧美日韩国产影院| 欧美亚洲视频一区二区| 国产在线精品成人一区二区三区| 日本精品视频在线观看| 亚洲91精品在线观看| 久久91亚洲精品中文字幕| 精品久久久久国产| 理论片在线不卡免费观看| 亚洲第一级黄色片| 欧美福利在线观看| 国产999在线观看| 久久国产精品久久国产精品| 久久久久久久爱| 久久久久99精品久久久久| 国产suv精品一区二区三区88区| 中文字幕亚洲在线| 日韩精品一二三四区| 国产精品自产拍在线观| 911国产网站尤物在线观看| 91av在线国产| 福利一区福利二区微拍刺激| 国产成人久久久| 国产91精品不卡视频| 理论片在线不卡免费观看| 亚洲成人激情图| 久久久精品国产网站| 国产成人久久精品| 久久免费精品日本久久中文字幕| 欧美尺度大的性做爰视频| 亚洲欧美日韩国产中文专区| 青草热久免费精品视频| 精品久久久久久久久久久久久| 日本精品久久久久影院| 欧美天天综合色影久久精品| 懂色av一区二区三区| 国产精品mp4| 国产精品扒开腿做爽爽爽男男| 亚洲少妇激情视频| 在线看片第一页欧美| 欧美极品少妇xxxxⅹ裸体艺术| 国产a∨精品一区二区三区不卡| 精品五月天久久| 国产精品男人爽免费视频1| 奇米成人av国产一区二区三区| 国产在线观看精品一区二区三区| 中文字幕精品www乱入免费视频| 日韩影视在线观看| 亚洲爱爱爱爱爱| 精品国产欧美一区二区五十路| 久久精品国产一区二区三区| 亚洲欧美日韩天堂一区二区| 最近2019中文字幕在线高清| 午夜精品久久久久久久99热浪潮| 日韩欧美综合在线视频| 亚洲色图15p| 97av在线视频| 日韩中文字幕在线精品| 日韩欧美一区二区三区| 久久夜色撩人精品| 国产乱肥老妇国产一区二| 国产一区二区三区视频在线观看| 2021久久精品国产99国产精品| 伊人激情综合网| 亚洲视频在线观看视频| 亚洲成**性毛茸茸| 亚洲91精品在线观看| 欧美日韩午夜视频在线观看| 日韩精品丝袜在线| 欧美电影在线观看高清| 日韩精品小视频| 97视频人免费观看| 伊人久久综合97精品| 91九色视频在线| 亚洲www永久成人夜色| 欧美wwwxxxx| 中文欧美日本在线资源| 亚洲日韩欧美视频一区| 亚洲精品久久久久久久久久久|