bzoj 1015 [JSOI2008]星球大戰starwar

來源:互聯網
上載者:User

標籤:include   個數   log   namespace   並查集   逆向   arw   size   space   

逆向考慮,先看作所有星球都被摧毀,然後恢複星球。

連通塊個數用並查集維護,每次恢複不能算被毀掉的星球

#include<cstdio>#include<vector>using namespace std;int n,m,k,fa[400001],x,y;vector<int> G[400001];int ans[400001];bool d[400001];int v[400001];bool vis[400001];int gf(int x){    if(fa[x]==x) return x;    return fa[x]=gf(fa[x]);}int main(){    scanf("%d%d",&n,&m);    for(int i=0;i<n;i++) fa[i]=i;    for(int i=1;i<=m;i++){        scanf("%d%d",&x,&y);        G[x].push_back(y);        G[y].push_back(x);    }    scanf("%d",&k);    int now=n;    for(int i=1;i<=k;i++){        scanf("%d",&v[i]);        d[v[i]]=1;    }    for(int i=0;i<n;i++){        if(!d[i]){            vis[i]=1;            for(int j=0;j<G[i].size();j++){                if(gf(i)!=gf(G[i][j])&&!d[G[i][j]]){                    now--;                    fa[gf(G[i][j])]=gf(i);                }            }        }    }    ans[k+1]=now-k;    for(int i=k;i>=1;i--){        ans[i]=ans[i+1]+1;vis[v[i]]=1;        for(int j=0;j<G[v[i]].size();j++){            if(gf(v[i])!=gf(G[v[i]][j])&&vis[G[v[i]][j]]){                ans[i]--;                fa[gf(G[v[i]][j])]=gf(v[i]);            }        }    }    for(int i=1;i<=k+1;i++)printf("%d\n",ans[i]);    return 0;}

 

bzoj 1015 [JSOI2008]星球大戰starwar

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.