1015: [JSOI2008]星球大战starwar

Time Limit: 3 Sec  Memory Limit: 162 MB
Submit: 5253  Solved: 2395
[Submit][Status][Discuss]

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 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

Sample Output

1
1
1
2
3
3

并查集不支持删除,所以倒着处理,每次加入一个点

用tot记录连通块个数,没加一个点就+1,遇到两个合并就-1,不会被破坏的点也用加的方法

加一个点是要便利它的所有边

  1. /**************************************************************
  2.     Problem: 1015
  3.     User: thwfhk
  4.     Language: C++
  5.     Result: Accepted
  6.     Time:1284 ms
  7.     Memory:13788 kb
  8. ****************************************************************/
  9.  
  10. //
  11. //  main.cpp
  12. //  bzoj1015
  13. //
  14. //  Created by Candy on 9/17/16.
  15. //  Copyright © 2016 Candy. All rights reserved.
  16. //
  17.  
  18. #include <iostream>
  19. #include <cstdio>
  20. #include <algorithm>
  21. #include <cmath>
  22. using namespace std;
  23. const int N=4e5+,M=2e5+;
  24. int read(){
  25.     char c=getchar();int x=,f=;
  26.     while(c<''||c>''){if(c=='-')f=-; c=getchar();}
  27.     while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
  28.     return x*f;
  29. }
  30. struct edge{
  31.     int v,ne;
  32. }e[M<<];
  33. int h[N],cnt=;
  34. inline void ins(int u,int v){
  35.     cnt++;
  36.     e[cnt].v=v;e[cnt].ne=h[u];h[u]=cnt;
  37.     cnt++;
  38.     e[cnt].v=u;e[cnt].ne=h[v];h[v]=cnt;
  39. }
  40.  
  41. int n,m,x,y,k,tot=,ans[N];
  42. int has[N],lst[N],vis[N];//vis for ins from 0
  43. int fa[N];
  44. int find(int x){return x==fa[x]?x:fa[x]=find(fa[x]);}
  45. inline void merge(int x,int y){
  46.     int f1=find(x),f2=find(y);
  47.     if(f1!=f2) fa[f1]=f2,tot--;
  48. }
  49. void add(int u){
  50.     for(int i=h[u];i;i=e[i].ne){
  51.         int v=e[i].v;
  52.         if(vis[v]) merge(u,v);
  53.     }
  54. }
  55. int main(int argc, const char * argv[]) {
  56.     n=read();m=read();
  57.     for(int i=;i<=m;i++){
  58.         x=read()+;y=read()+;ins(x,y);
  59.     }
  60.     k=read();
  61.     for(int i=;i<=n;i++) has[i]=,fa[i]=i;
  62.     for(int i=;i<=k;i++){
  63.         x=read()+;
  64.         has[x]=;
  65.         lst[i]=x;
  66.     }
  67.      
  68.     for(int u=;u<=n;u++)
  69.         if(has[u]){
  70.             tot++;
  71.             add(u);
  72.             vis[u]=;
  73.         }
  74.      
  75.     ans[k+]=tot;
  76.     for(int i=k;i>=;i--){
  77.         tot++;
  78.         add(lst[i]);
  79.         vis[lst[i]]=;
  80.         ans[i]=tot;
  81.     }
  82.     for(int i=;i<=k+;i++) printf("%d\n",ans[i]);
  83.     return ;
  84. }

[2016-11-15]

注意一开始也要求一下cc个数

加入一个点可能连起好多个cc来,用并查集维护连通性

  1. #include <iostream>
  2. #include <cstdio>
  3. #include <cstring>
  4. #include <algorithm>
  5. #include <cmath>
  6. using namespace std;
  7. const int N=4e5+,M=2e5+,INF=1e9;
  8. inline int read(){
  9. char c=getchar();int x=,f=;
  10. while(c<''||c>''){if(c=='-')f=-;c=getchar();}
  11. while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
  12. return x*f;
  13. }
  14. int n,m,k,a[N],des[N],x,y,ans[N];
  15. struct edge{
  16. int v,w,ne;
  17. }e[M<<];
  18. int h[N],cnt=;
  19. inline void ins(int u,int v){
  20. cnt++;
  21. e[cnt].v=v;e[cnt].ne=h[u];h[u]=cnt;
  22. cnt++;
  23. e[cnt].v=u;e[cnt].ne=h[v];h[v]=cnt;
  24. }
  25.  
  26. int fa[N];
  27. inline int find(int x){return x==fa[x]?x:fa[x]=find(fa[x]);}
  28. int tot=;
  29. inline void unn(int x,int y){
  30. int f1=find(x),f2=find(y);
  31. if(f1!=f2) fa[f1]=f2,tot--;
  32. }
  33. void add(int u){
  34. for(int i=h[u];i;i=e[i].ne){
  35. int v=e[i].v;
  36. if(!des[v]) unn(u,v);
  37. }
  38. }
  39. int main(){
  40. n=read();m=read();
  41. for(int i=;i<=m;i++){x=read()+;y=read()+;ins(x,y);}
  42. k=read();
  43. for(int i=;i<=k;i++) a[i]=read()+,des[a[i]]=;
  44.  
  45. for(int i=;i<=n;i++) fa[i]=i;
  46. for(int i=;i<=n;i++) if(!des[i]){
  47. tot++;
  48. add(i);
  49. }
  50. ans[k+]=tot;
  51. for(int i=k;i>=;i--){
  52. tot++;
  53. des[a[i]]=;
  54. add(a[i]);
  55. ans[i]=tot;
  56. }
  57. for(int i=;i<=k+;i++) printf("%d\n",ans[i]);
  58. }

BZOJ1015[JSOI2008]星球大战starwar[并查集]的更多相关文章

  1. [洛谷P1197/BZOJ1015][JSOI2008]星球大战Starwar - 并查集,离线,联通块

    Description 很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治者整个星系.某一天,凭着一个偶然的机遇,一支反抗军摧毁了帝国的超级武器,并攻下了星系中几乎所有的星球.这些星球通过 ...

  2. bzoj1015: [JSOI2008]星球大战starwar 并查集+离线处理

    题目传送门 这道题可以改为离线处理 倒着找答案 这样删点就变成加点了 有了这个思想题目就很好写了哇 23333 #include<cstdio> #include<cstring&g ...

  3. BZOJ 1015: [JSOI2008]星球大战starwar 并查集

    1015: [JSOI2008]星球大战starwar Description 很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治者整个星系.某一天,凭着一个偶然的机遇,一支反抗军摧毁了帝 ...

  4. BZOJ_1015_[JSOI2008]星球大战_并查集

    BZOJ_1015_[JSOI2008]星球大战_并查集 题意:很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治者整个星系.某一天,凭着一个偶然的 机遇,一支反抗军摧毁了帝国的超级武器, ...

  5. P1197 [JSOI2008]星球大战(并查集判断连通块+正难则反)

    P1197 [JSOI2008]星球大战(并查集判断连通块+正难则反) 并查集本来就是连一对不同父亲的节点就的话连通块就少一个. 题目描述 很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统 ...

  6. BZOJ1015 [JSOI2008]星球大战starwar(并查集)

    1015: [JSOI2008]星球大战starwar Time Limit: 3 Sec  Memory Limit: 162 MBSubmit: 3895  Solved: 1750[Submit ...

  7. [Bzoj1015][JSOI2008]星球大战starwar(并查集)(离线处理)

    1015: [JSOI2008]星球大战starwar Time Limit: 3 Sec  Memory Limit: 162 MBSubmit: 6849  Solved: 3204[Submit ...

  8. 星球大战starwar(并查集)

    1015: [JSOI2008]星球大战starwar Time Limit: 3 Sec  Memory Limit: 162 MBSubmit: 5253  Solved: 2395[Submit ...

  9. 2018.09.26 bzoj1015: [JSOI2008]星球大战starwar(并查集)

    传送门 并查集经典题目. 传统题都是把删边变成倒着加边,这道题是需要倒着加点. 处理方法是将每个点与其他点的边用一个vector存起来,加点时用并查集统计答案就行了. 代码: #include< ...

随机推荐

  1. 【前端盲点】DOM事件流论证CSS盒模型是否具有厚度

    前言 很久没有扯淡了,我们今天来扯淡吧. 我今天思考了一个问题,我们页面的dom树到底是如何渲染的,而CSS盒模型与javascript是否有联系,于是便想到一个问题: CSS的盒模型具有厚度么??? ...

  2. iOS UIView设置圆角

    UIView设置圆角 1.比较简单的情况,UIView四个角都是圆角: UIView *aView = [[UIView alloc] init]; aView.frame = CGRectMake( ...

  3. Servlet基础(二) Servlet的生命周期

    Servlet基础(二) Servlet的生命周期 Servlet的生命周期可以分为三个阶段: 1.初始化阶段 2.响应客户请求阶段 3.终止阶段 Servlet的初始化阶段 在下列时刻Servlet ...

  4. Android 网络HTML查看器

    本文实现一个基于Android的网络HTML查看器 新建项目,项目布局文件如下: <LinearLayout xmlns:android="http://schemas.android ...

  5. 【代码笔记】iOS-饼图

    一,效果图. 二,工程图. 三,代码. RootViewController.h #import <UIKit/UIKit.h> @class QuizChartView; @interf ...

  6. OC中的Block的那些事

    Block封装了一段代码,可以在任何时候执行 Block可以作为函数参数或者函数的返回值,而其本身又可以带输入参数或返回值. 苹果官方建议尽量多用block.在多线程.异步任务.集合遍历.集合排序.动 ...

  7. DB2LOOK命令提取数据库对象信息

    提取复制数据库的DDL语句:db2look -d BCDLJS -e -o db2look.sql -a -a:导出所有用户的DDL-o: 定向结果到文件-d: 数据库名-e: 抽取复制数据库所需的 ...

  8. linux下安装jdk+tomcat+eclipse+mysql

    我的环境:主机是win7的,虚拟机是VWare  Workstation 6.0   ,linux系统为Red Hat Enterprise  Linux 5 64位 各软件版本:jdk是jdk-6u ...

  9. nginx 配置优化的几个参数(转)

    nginx配置文件里面需要注意的一些参数 worker_processes 8  nginx要开启的进程数 一般等于cpu的总核数 其实一般情况下开4个或8个就可 我开2个 以了 多了没有太多用每个n ...

  10. Nodejs——包与NPM

    在模块之外,包和NPM则是将模块联系起来的一种机制. CommonJS的包规范由包结构和包描述文件组成. 包实际上是一个存档文件,即一个目录直接打包为.zip或tar.gz格式的文件. 完全符合Com ...