JSOI2008星球大戰(並查集)

來源:互聯網
上載者:User

標籤:des   c   style   class   blog   code   

膜拜HZWER大牛的編碼能力!

附上他的代碼(My Code不知為何一直莫名出錯……)

#include<iostream>#include<cstdio>#include<cstring>using namespace std;int tot,n,m,d,father[400001],head[400001],q[400001],ans[400001],cnt=1;bool used[400001],des[400001];struct data{int to,next;}e[400001];int find(int x){return x==father[x]?x:father[x]=find(father[x]);}void ins(int u,int v){     cnt++;e[cnt].to=v;e[cnt].next=head[u];head[u]=cnt;     cnt++;e[cnt].to=u;e[cnt].next=head[v];head[v]=cnt; }void add(int x){    int i=head[x],p=find(x),q;    while(i)    {        if(used[e[i].to])        {             q=find(e[i].to);             if(p!=q){father[q]=p;tot--;}        }        i=e[i].next;            }  }int main(){    scanf("%d%d",&n,&m);    for(int i=0;i<n;i++)father[i]=i;    for(int i=1;i<=m;i++)    {            int x,y;            scanf("%d%d",&x,&y);            ins(x,y);            }    scanf("%d",&d);    for(int i=1;i<=d;i++)    {            scanf("%d",&q[i]);            des[q[i]]=1;             }    for(int i=0;i<n;i++)    {        if(!des[i])        {                   tot++;                   add(i);                   used[i]=1;        }    }    ans[d+1]=tot;    for(int i=d;i>0;i--)    {            tot++;            add(q[i]);            used[q[i]]=1;            ans[i]=tot;            }    for(int i=1;i<=d+1;i++)printf("%d\n",ans[i]);    return 0;}

 

聯繫我們

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