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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

JZOJ 3453【NOIP2013中秋节模拟】连通块

發(fā)布時間:2025/3/15 编程问答 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JZOJ 3453【NOIP2013中秋节模拟】连通块 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

原題

Description

你應該知道無向圖的連通塊的數(shù)量,你應該知道如何求連通塊的數(shù)量。當你興奮與你的成就時,破壞王Alice拆掉了圖中的邊。當她發(fā)現(xiàn),每刪去一條邊,你都會記下邊的編號,同時告訴她當前連通塊的個數(shù)。

然而,對邊編號簡直就是個悲劇,因為Alice為了刁難你,拆掉編號從l到r的邊,當然你需要做的事情就是求連通塊的個數(shù)。如果你答對了,Alice會把拆掉的邊裝好,迚行下一次破壞。如果你無法完成這個任務,Alice會徹底毀了你的圖。

進行完足夠多次之后,Alice覺得無聊,就玩去了,而你卻需要繼續(xù)做第三題。

Input

第一行兩個整數(shù)n,m,表示點數(shù)和邊數(shù)。

之后m行每行兩個整數(shù)x,y,表示x與y之間有無向邊。(按讀入順序給邊編號,編號從1開始)

一行一個整數(shù)k,表示Alice的破壞次數(shù)。

之后k行,每行兩個整數(shù)l,r。

Output

k行,每行一個整數(shù)。

Sample Input

6 5

1 2

5 4

2 3

3 1

3 6

6

1 3

2 5

1 5

5 5

2 4

3 3

Sample Output

4

5

6

3

4

2

Data Constraint

對于30%的數(shù)據(jù),n<=100,k<=10

對于60%的數(shù)據(jù),k<=1000

對于100%的數(shù)據(jù),n<=500,m<=10000,k<=20000,1<=l<=r<=m

題解

  • 并查集。Collect!

  • 每一個 f[i] 為一個并查集,記錄只添加前 i 條邊時,所有節(jié)點的聯(lián)通情況。

  • 每一個 g[i] 也是一個并查集,記錄只添加 im 條邊時,所有節(jié)點的聯(lián)通情況。

  • 對于每個詢問只要把 f[l?1]g[r+1] 合并至 H[] 中。

  • 最后在 H[] 中判斷即可。

Code

#include<cstdio> #include<cstring> using namespace std; int n,m; struct data {int x,y; }a[10002]; int f[10002][501],g[10002][501],h[501]; inline int read() {int data=0; char ch=0;while(ch<'0' || ch>'9') ch=getchar();while(ch>='0' && ch<='9') data=data*10+ch-'0',ch=getchar();return data; }//讀入優(yōu)化 inline int getf(int k,int x) {if(f[k][x]==x) return x;return f[k][x]=getf(k,f[k][x]); }//F的查找 inline int getg(int k,int x) {if(g[k][x]==x) return x;return g[k][x]=getg(k,g[k][x]); }//G的查找 void init() {n=read();m=read();for(int i=1;i<=m;i++) a[i].x=read(),a[i].y=read();for(int i=1;i<=n;i++) f[0][i]=g[m+1][i]=i;//初值for(int i=1;i<=m;i++){memcpy(f[i],f[i-1],sizeof(f[i]));f[i][getf(i,a[i].x)]=getf(i,a[i].y);}//F的處理for(int i=m;i;i--){memcpy(g[i],g[i+1],sizeof(g[i]));g[i][getg(i,a[i].x)]=getg(i,a[i].y);}//G的處理 } inline int geth(int x) {if(h[x]==x) return x;return h[x]=geth(h[x]); }//H的查找 void work() {int k=read();while(k--){int l=read()-1,r=read()+1;memcpy(h,f[l],sizeof(h));for(int i=1;i<=n;i++) h[geth(h[i])]=geth(g[r][i]);//H的處理int ans=0;for(int i=1;i<=n;i++)if(h[i]==i) ans++;//H的判斷printf("%d\n",ans);} } int main() {freopen("connect.in","r",stdin);freopen("connect.out","w",stdout);init();work();return 0; }

總結

以上是生活随笔為你收集整理的JZOJ 3453【NOIP2013中秋节模拟】连通块的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。