zoukankan      html  css  js  c++  java
  • 洛谷 P1197 [JSOI2008]星球大战

    题目描述

    很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治者整个星系。某一天,凭着一个偶然的机遇,一支反抗军摧毁了帝国的超级武器,并攻下了星系中几乎所有的星球。这些星球通过特殊的以太隧道互相直接或间接地连接。

    但好景不长,很快帝国又重新造出了他的超级武器。凭借这超级武器的力量,帝国开始有计划地摧毁反抗军占领的星球。由于星球的不断被摧毁,两个星球之间的通讯通道也开始不可靠起来。现在,反抗军首领交给你一个任务:给出原来两个星球之间的以太隧道连通情况以及帝国打击的星球顺序,以尽量快的速度求出每一次打击之后反抗军占据的星球的连通快的个数。(如果两个星球可以通过现存的以太通道直接或间接地连通,则这两个星球在同一个连通块中)。

    输入输出格式

    输入格式:

    输入文件第一行包含两个整数,N (1 <= N <= 2M) 和M (1 <= M <= 200,000),分别表示星球的数目和以太隧道的数目。星球用0~N-1的整数编号。

    接下来的M行,每行包括两个整数X, Y,其中(0<=X<>Y<N),表示星球X和星球Y之间有以太隧道。注意所有的以太隧道都是双向的。

    接下来一行是一个整数K,表示帝国计划打击的星球个数。

    接下来的K行每行一个整数X,满足0<=X<N,表示帝国计划打击的星球编号。帝国总是按输入的顺序依次摧毁星球的。

    输出格式:

    输出文件的第一行是开始时星球的连通块个数。

    接下来的K行,每行一个整数,表示经过该次打击后现存星球的连通块个数。

    输入输出样例

    输入样例#1:
    8 13
    0 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
    
    输出样例#1:
    1
    1
    1
    2
    3
    3

    说明

    [JSOI2008]

     1 #include<iostream>
     2 #include<cstdio>
     3 #include<cstring>
     4 #include<algorithm>
     5 
     6 using namespace std;
     7 
     8 const int N = 400005;
     9 
    10 int head[N],tot,p[N],c[N],ans[N];
    11 
    12 bool pan[N];
    13 
    14 struct node
    15 {
    16     int next,v;
    17 }edge[N];
    18 
    19 void add(int a,int b)
    20 {
    21     edge[tot].v=b;
    22     edge[tot].next=head[a];
    23     head[a]=tot++;
    24 }
    25 
    26 int getfa(int x)
    27 { 
    28     return p[x]==x?x:p[x]=getfa(p[x]); 
    29 }
    30 
    31 int main()
    32 {
    33     int a,b,n,m,k; 
    34     memset(head,-1,sizeof(head));
    35     scanf("%d%d",&n,&m);
    36     for(int i=0;i<n;i++) p[i]=i;
    37     for(int i=1;i<=m;i++)
    38     {
    39         scanf("%d%d",&a,&b);
    40         add(a,b);add(b,a);
    41     }
    42     scanf("%d",&k);
    43     for(int i=0;i<k;i++)
    44     {
    45         scanf("%d",&c[i]);
    46         pan[c[i]]=true;
    47     }
    48     
    49     for(int i=0;i<n;i++)
    50     {
    51         if(!pan[i])
    52         for(int j = head[i];~j;j = edge[j].next)
    53         {
    54             if(pan[edge[j].v])continue;
    55             int x=getfa(i);
    56             int y=getfa(edge[j].v);
    57             p[x] = y;
    58         } 
    59     }
    60     
    61     for(int i=0;i<n;i++) if(!pan[i] && getfa(i) == i)ans[k]++;  
    62     
    63     for(int i=k-1;i>=0;i--)
    64     {
    65         int x=0;
    66         pan[c[i]] = false;
    67         for(int j = head[c[i]];j!=-1;j = edge[j].next)
    68         {
    69             if(!pan[edge[j].v])
    70             {
    71                 int z=getfa(c[i]);int y=getfa(edge[j].v);
    72                 if(z != y)
    73                 {
    74                     p[z]=y;
    75                     x++;
    76                 }
    77             }
    78         }
    79         ans[i]=ans[i+1]-x+1;
    80     }
    81     
    82     for(int i=0;i<=k;i++)printf("%d
    ",ans[i]);
    83     return 0;
    84 }
  • 相关阅读:
    小试阿里云容器服务
    .NET跨平台:再见dnx,你好dotnet cli
    使用Let's Encrypt手动创建https证书
    Chrome以https访问gitlab的问题:Your connection is not private
    [ASP.NET 5]终于解决:Unable to load DLL 'api-ms-win-core-localization-obsolete-l1-2-0.dll'
    Mac上远程桌面连接Windows Server 2012 R2
    解决JSON.stringify()在IE10下无法使用的问题
    解决阿里云SLB无法添加https证书的问题
    “状态机”学习笔记
    HttpClient读取ASP.NET Web API错误信息的简单方法
  • 原文地址:https://www.cnblogs.com/lyqlyq/p/6875034.html
Copyright © 2011-2022 走看看