值得一做》关于并查集的进化题目 BZOJ1015(BZOJ第一页计划)(normal-)
這道題和以前做過的一道經典的洪水沖橋問題很像,主要做法是逆向思維。(BZOJ第10道非SB題紀念)
先給出題目
Description
很久以前,在一個遙遠的星系,一個黑暗的帝國靠著它的超級武器統治者整個星系。某一天,憑著一個偶然的
機遇,一支反抗軍摧毀了帝國的超級武器,并攻下了星系中幾乎所有的星球。這些星球通過特殊的以太隧道互相直
接或間接地連接。 但好景不長,很快帝國又重新造出了他的超級武器。憑借這超級武器的力量,帝國開始有計劃
地摧毀反抗軍占領的星球。由于星球的不斷被摧毀,兩個星球之間的通訊通道也開始不可靠起來。現在,反抗軍首
領交給你一個任務:給出原來兩個星球之間的以太隧道連通情況以及帝國打擊的星球順序,以盡量快的速度求出每
一次打擊之后反抗軍占據的星球的連通快的個數。(如果兩個星球可以通過現存的以太通道直接或間接地連通,則
這兩個星球在同一個連通塊中)。
Input
輸入文件第一行包含兩個整數,N (1? < =? N? < =? 2M) 和M (1? < =? M? < =? 200,000),分別表示星球的數目和以太隧道的數目。星球用 0 ~ N-1的整數編號。接下來的M行,每行包括兩個整數X, Y,其中(0 < = X <>Y 表示星球x和星球y之間有“以太”隧道,可以直接通訊。接下來的一行為一個整數k,表示將遭受攻擊的星球的數目。接下來的k行,每行有一個整數,按照順序列出了帝國軍的攻擊目標。這k個數互不相同,且都在0到n-1的范圍內。
Output
輸出文件的第一行是開始時星球的連通塊個數。接下來的N行,每行一個整數,表示經過該次打擊后現存星球的連通塊個數。
Sample Input
8 130 1
1 6
6 5
5 0
0 6
1 2
2 3
3 4
4 5
7 1
7 2
7 6
3 6
5
1
6
3
5
7
Sample Output
11
1
2
3
3 對于這道題,每次摧毀一個點,直接一遍一遍維護強連通分量,是基本不可做的。 所以我們可以試著考慮倒著做。 先加入那些從始至終也沒有被摧毀的點,然后倒著維護:每次新加入點后強連通分量的個數,用并查集維護這一過程。(這我數組開小了調的大半天/再見)
然后局部地方稍微優化 1 #include<stdio.h> 2 struct shit{ 3 int aim,next; 4 }e[401000]; 5 int head[401000],num,s[401000],ans[401000],rank[401000],fa[401000],point; 6 bool mp[401000],us[401000]; 7 int find(int x){return x==fa[x]?x:fa[x]=find(fa[x]);} 8 void fuck(int x,int y) 9 { 10 e[++point].aim=y,e[point].next=head[x],head[x]=point; 11 } 12 void insert(int x) 13 { 14 int i=head[x],p=find(x),q; 15 while(i) 16 { 17 if(us[e[i].aim]) 18 { 19 q=find(e[i].aim); 20 if(q!=p)fa[q]=p,num--; 21 } 22 i=e[i].next; 23 } 24 } 25 int main() 26 { 27 int d,n,m,a,b; 28 scanf("%d%d",&n,&m); 29 for(int i=1;i<=n;++i)fa[i]=i; 30 for(int i=1;i<=m;++i) 31 { 32 scanf("%d%d",&a,&b); 33 fuck(a,b); 34 fuck(b,a); 35 } 36 scanf("%d",&d); 37 for(int i=1;i<=d;++i) 38 { 39 scanf("%d",&s[i]); 40 mp[s[i]]=true; 41 } 42 for(int i=0;i<n;++i) 43 if(!mp[i]) 44 { 45 num++; 46 insert(i); 47 us[i]=true; 48 } 49 ans[d+1]=num; 50 for(int i=d;i;i--) 51 { 52 num++; 53 insert(s[i]); 54 us[s[i]]=true; 55 ans[i]=num; 56 } 57 for(int i=1;i<=d+1;++i)printf("%d\n",ans[i]); 58 return 0; 59 } View Code
?
轉載于:https://www.cnblogs.com/PencilWang/p/5925324.html
總結
以上是生活随笔為你收集整理的值得一做》关于并查集的进化题目 BZOJ1015(BZOJ第一页计划)(normal-)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 梦到辣椒是什么意思
- 下一篇: 梦到猫咬我是什么意思周公解梦