URAL 1671 Anansi's Cobweb (並查集)

來源:互聯網
上載者:User

標籤:style   blog   http   color   os   io   for   art   

題意:給一個無向圖。每次查詢破壞一條邊,每次輸出查詢後連通圖的個數。

思路:並查集。逆向思維,刪邊變成加邊。

 

#include<cstdio>#include<cstring>#include<algorithm>#include<vector>#include<iostream>#define inf -100000000#define LL long long#define maxn 100005using namespace std;struct Edge{    int x,y;};int parent[maxn];int findset(int p){    return (parent[p]==p)?p:(parent[p]=findset(parent[p]));}Edge edge[maxn];int query[maxn];bool build[maxn];int ans[maxn];int main(){    int n,m;    while(scanf("%d%d",&n,&m)!=EOF)    {        memset(build,0,sizeof(build));        for(int i=1; i<=m; ++i)            scanf("%d%d",&edge[i].x,&edge[i].y);        int q;        scanf("%d",&q);        for(int i=1; i<=q; ++i)        {            scanf("%d",&query[i]);            build[query[i]]=true;        }        for(int i=1; i<=n; ++i)            parent[i]=i;        int cnt=0;        for(int i=1; i<=m; ++i)            if(!build[i])            {                int fa=findset(edge[i].x),fb=findset(edge[i].y);                if(fa!=fb)                    parent[fa]=fb;            }        for(int i=1; i<=n; ++i)            if(findset(i)==i) cnt++;        for(int i=q; i>=1; --i)        {            ans[i]=cnt;            int fa=findset(edge[query[i]].x),fb=findset(edge[query[i]].y);            if(fa!=fb)            {                parent[fa]=fb;                cnt--;            }        }        for(int i=1; i<=q; ++i)            if(i==1) printf("%d",ans[i]);            else printf(" %d",ans[i]);        printf("\n");    }    return 0;}
View Code

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.