日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

CodeForces - 571D Campus(数据结构综合)

發布時間:2024/4/11 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 CodeForces - 571D Campus(数据结构综合) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目鏈接:點擊查看

題目大意:

題目分析:數據結構的題目寫起來真好玩~(debug到吐)

考慮離線,題目實質上就是維護兩個森林,然后對同一個序列進行的賦值操作,如果是對單一的森林進行加邊刪邊然后連通塊內求值修改之類的話,不難想到克魯斯卡爾重構樹,但兩個森林的話該怎么辦呢

注意到第一個森林中對連通塊的操作是加法,第二個森林中對連通塊的操作是置零

任取一個點 x 進行討論,假設現在不考慮第二個森林的貢獻,也就是忽略掉第二種操作和第四種操作,并且在每次操作后都記錄一下點 x 的值,更具體的,設 val_x[ i?] 是在經過第 i 個操作后,點 x 的值

現在假設第 r 個操作是?“ Q x ”,也就是在第 r 個操作時需要輸出 x 的值,但并不是需要輸出 val_x[ r ] ,因為 val_x 記錄的只是第一個森林的貢獻,為了計算總貢獻,我們需要知道在第 r 個操作之前,對于點 x 來說距離最近的一次操作 4,也就是第二個森林的置零操作,找到的這個位置記為 l,換句話說,現在在第 l 個操作時將點 x 置零,需要輸出第 r 個操作時 x 的值,也就是說在閉區間 [ l + 1 , r ] 內 val_x 的值只受到了第一個森林的影響,到此為止不難想到答案就是 val_x[ r ] - val_x[ l ] 了

綜上所述,我們將問題又進行了進一步的轉換:

  • 先通過第二個森林求出每一個操作 Q x 的可行區間 [ l , r ] ,滿足:
  • 當前的操作 Q x 是第 r 次操作
  • 第 l 次操作是對于點 x 進行的置零操作
  • 閉區間 [ l + 1 , r ] 內再無對于點 x 進行的置零操作
  • 再通過第二個森林去維護每個點的 val_x,對于一個操作 Q x 來說,其通過上述操作求出的區間為 [ l , r ] ,那么在其 l 位置減去 val_x[ l ],在其 r 位置減去 val_x[ r ] 就是操作 Q x 的答案
  • 這樣就將第一個森林和第二個森林各自的作用區分開來,轉換成了兩個獨立的森林提供的貢獻

    剩下的用克魯斯卡爾重構樹亂搞就好了

    代碼:
    ?

    //#pragma GCC optimize(2) //#pragma GCC optimize("Ofast","inline","-ffast-math") //#pragma GCC target("avx,sse2,sse3,sse4,mmx") #include<iostream> #include<cstdio> #include<string> #include<ctime> #include<cmath> #include<cstring> #include<algorithm> #include<stack> #include<climits> #include<queue> #include<map> #include<set> #include<sstream> #include<cassert> #include<bitset> #include<unordered_map> using namespace std;typedef long long LL;typedef unsigned long long ull;const int inf=0x3f3f3f3f;const int N=1e6+100;char op[N][2];int n,m,a[N];LL ans[N];vector<int>q[N];struct Ex_Kruskal {int f[N],L[N],R[N],sz[N],tot,index;vector<int>node[N];void init(int n){tot=0;index=n;for(int i=0;i<=n<<1;i++)f[i]=i;}int find(int x){return f[x]==x?x:f[x]=find(f[x]);}void addedge(int x,int y){int xx=find(x),yy=find(y);if(xx!=yy){f[xx]=f[yy]=++index;node[index].push_back(xx);node[index].push_back(yy);}}void dfs(int u){L[u]=++tot;sz[u]=(u<=n);for(auto v:node[u]){dfs(v);sz[u]+=sz[v];}R[u]=tot;} };struct Set1 {Ex_Kruskal kru;int n;struct Node{int l,r;LL sum;}tree[N<<2];void get_dfs(){n=kru.index;for(int i=1;i<=n;i++)if(kru.find(i)==i)kru.dfs(i);}void pushdown(int k){if(tree[k].sum){tree[k<<1].sum+=tree[k].sum;tree[k<<1|1].sum+=tree[k].sum;tree[k].sum=0;}}void build(int k,int l,int r){tree[k].l=l;tree[k].r=r;tree[k].sum=0;if(l==r)return;int mid=l+r>>1;build(k<<1,l,mid);build(k<<1|1,mid+1,r);}void update(int k,int l,int r,int val){if(tree[k].l>r||tree[k].r<l)return;if(tree[k].l>=l&&tree[k].r<=r){tree[k].sum+=val;return;}pushdown(k);update(k<<1,l,r,val);update(k<<1|1,l,r,val);}void change(int x){update(1,kru.L[a[x]],kru.R[a[x]],kru.sz[a[x]]);}LL query(int k,int pos){if(tree[k].l==tree[k].r)return tree[k].sum;pushdown(k);int mid=tree[k].l+tree[k].r>>1;if(pos<=mid)return query(k<<1,pos);elsereturn query(k<<1|1,pos);}LL ask(int x){return query(1,kru.L[a[x]]);} }t1;struct Set2 {Ex_Kruskal kru;int n;struct Node{int l,r;int time;}tree[N<<2];void get_dfs(){n=kru.index;for(int i=1;i<=n;i++)if(kru.find(i)==i)kru.dfs(i);}void pushdown(int k){if(tree[k].time){tree[k<<1].time=tree[k<<1|1].time=tree[k].time;tree[k].time=0;}}void build(int k,int l,int r){tree[k].l=l;tree[k].r=r;tree[k].time=0;if(l==r)return;int mid=l+r>>1;build(k<<1,l,mid);build(k<<1|1,mid+1,r);}void update(int k,int l,int r,int val){if(tree[k].l>r||tree[k].r<l)return;if(tree[k].l>=l&&tree[k].r<=r){tree[k].time=val;return;}pushdown(k);update(k<<1,l,r,val);update(k<<1|1,l,r,val);}void change(int x){update(1,kru.L[a[x]],kru.R[a[x]],x);}int query(int k,int pos){if(tree[k].l==tree[k].r)return tree[k].time;pushdown(k);int mid=tree[k].l+tree[k].r>>1;if(pos<=mid)return query(k<<1,pos);elsereturn query(k<<1|1,pos);}int ask(int x){return query(1,kru.L[a[x]]);} }t2;int main() { #ifndef ONLINE_JUDGE // freopen("data.in.txt","r",stdin); // freopen("data.out.txt","w",stdout); #endif // ios::sync_with_stdio(false);scanf("%d%d",&n,&m);t1.kru.init(n),t2.kru.init(n);for(int i=1,x,y;i<=m;i++){scanf("%s%d",op[i],&x);switch(op[i][0]){case 'U':scanf("%d",&y);t1.kru.addedge(x,y);break; case 'M':scanf("%d",&y);t2.kru.addedge(x,y);break;case 'A':a[i]=t1.kru.find(x);break;case 'Z':a[i]=t2.kru.find(x);break;case 'Q':a[i]=x;break;}}t1.get_dfs(),t2.get_dfs();t1.build(1,1,t1.n),t2.build(1,1,t2.n);for(int i=1;i<=m;i++){switch(op[i][0]){case 'Z':t2.change(i);break;case 'Q':q[t2.ask(i)].push_back(i);break;}}for(int i=1;i<=m;i++){switch(op[i][0]){case 'A':t1.change(i);break;case 'Z':for(auto it:q[i])ans[it]-=t1.ask(it);break;case 'Q':ans[i]+=t1.ask(i);break;}}for(int i=1;i<=m;i++)if(op[i][0]=='Q')printf("%lld\n",ans[i]);return 0; }

    ?

    總結

    以上是生活随笔為你收集整理的CodeForces - 571D Campus(数据结构综合)的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 雪花飘电影在线观看免费高清 | 涩涩网站在线 | 亚洲毛片一区二区三区 | 国产原创剧情av | 中文在线观看高清视频 | 国精产品一区二区 | 亚洲视频123| 小日子的在线观看免费第8集 | 波多野结衣在线观看一区 | 夜夜草视频 | 朴银狐电影中文在线看 | 日本色一区 | 欧美成人高潮一二区在线看 | 色片免费观看 | 国产h片在线观看 | aaaaa毛片| 亚洲精品久久久蜜桃网尤妮丝 | 欧美精品二区三区四区免费看视频 | 超碰88| 亚洲高清在线播放 | 成人爽爽视频 | 三级网站视频 | 男女国产视频 | 成人网在线播放 | 91重口味 | 白丝校花扒腿让我c | 国产一区二区三区四区在线观看 | 亚洲欧美在线观看视频 | 欧美s码亚洲码精品m码 | 欧美性猛交xxxx乱大交 | 国产成人综合一区二区三区 | 91黄色短视频| 男人的天堂在线观看av | 久久久久久久久久久久久久久久久 | 中国大陆高清aⅴ毛片 | 爆操巨乳 | 亚洲天堂影视 | 日本伊人久久 | 日本波多野结衣在线 | 亚洲一级av无码毛片精品 | 一直草| 一级片免费看视频 | 五月天免费网站 | 成人黄色免费看 | 久久成人在线观看 | 九九热九九爱 | 中文字幕不卡在线观看 | 人妻与黑人一区二区三区 | 超碰97在线资源 | 人人澡人人看 | 男人天堂a | 一级做a爰片 | 9人人澡人人爽人人精品 | 久久综合亚洲 | 国产精品精品视频 | 99久久影院 | 欧美激情一区二区三区免费观看 | 激情中文字幕 | 97超碰免费在线 | 天天影视亚洲 | 5级黄色片 | 久久久欧美 | 五月天欧美| 成年人黄色一级片 | 五月婷婷开心 | 日本视频二区 | 另类视频在线观看 | www.插插插.com| 在线观看网址你懂的 | 久久久久久国产免费a片 | 久久久久久日产精品 | 中文字幕在线播出 | www视频免费观看 | 伊人久久大 | 亚洲国产私拍精品国模在线观看 | 七月丁香婷婷 | 亚洲一二区 | 在线不卡的av| 91成人国产综合久久精品 | 午夜操一操 | 香蕉av一区二区 | 97青草| 一边摸内裤一边吻胸 | 久久综合伊人77777麻豆 | 综合久久久久久久 | 办公室摸腿吻胸激情视频 | av一区二 | 亚欧乱色 | 黄色片久久 | 国产视频一区二区三区四区 | 欧美韩一区 | 九九久久国产 | 日韩黄色大全 | 永久免费看mv网站入口78 | 性欧美丰满熟妇xxxx性仙踪林 | 日韩在线视频你懂的 | 男人天堂avav | 欧美视频导航 | a视频在线免费观看 |