L2-013 红色警报(25 分)
战争中保持各个城市间的连通性非常重要。本题要求你编写一个报警程序,当失去一个城市导致国家被分裂为多个无法连通的区域时,就发出红色警报。注意:若该国本来就不完全连通,是分裂的k个区域,而失去一个城市并不改变其他城市之间的连通性,则不要发出警报。

输入格式:

输入在第一行给出两个整数N(0 < N <=500)和M(<=5000),分别为城市个数(于是默认城市从0到N-1编号)和连接两城市的通路条数。随后M行,每行给出一条通路所连接的两个城市的编号,其间以1个空格分隔。在城市信息之后给出被攻占的信息,即一个正整数K和随后的K个被攻占的城市的编号。

注意:输入保证给出的被攻占的城市编号都是合法的且无重复,但并不保证给出的通路没有重复。

输出格式:

对每个被攻占的城市,如果它会改变整个国家的连通性,则输出“Red Alert: City k is lost!”,其中k是该城市的编号;否则只输出“City k is lost.”即可。如果该国失去了最后一个城市,则增加一行输出“Game Over.”。

输入样例:

5 4
0 1
1 3
3 0
0 4
5
1 2 0 4 3
输出样例:

City 1 is lost.
City 2 is lost.
Red Alert: City 0 is lost!
City 4 is lost.
City 3 is lost.
Game Over.

方法一:用dfs判断是否连通并且计算连通数

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
#include<cstdio>
#include<cstring>
using namespace std;
const int maxm = 550;
int edge[maxm][maxm];
int visit[maxm],n;
void (int x){
visit[x] = 1;
for(int i=0;i<n;i++){
if(!visit[i]&&edge[x][i]){
dfs(i);
}
}
}
int Calcnt(){
int cnt = 0;
for(int i=0;i<n;i++){
if(!visit[i]){
dfs(i);
cnt++;
}
}
return cnt;
}
int main()
{
int m;
scanf("%d%d",&n,&m);
memset(edge,0,sizeof(edge));
memset(visit,0,sizeof(visit));
for(int i=0;i<m;i++){
int a,b;
scanf("%d%d",&a,&b);
edge[a][b] = 1;
edge[b][a] = 1;
}
int cntt = Calcnt();
int k,city;
scanf("%d",&k);
for(int i=0;i<k;i++){
scanf("%d",&city);
for(int j=0;j<n;j++){
if(edge[city][j]){
edge[city][j] = 0;
edge[j][city] = 0;
}
}
memset(visit,0,sizeof(visit));
int temp = Calcnt();
if(temp>cntt+1){
printf("Red Alert: City %d is lost!n",city);
}else{
printf("City %d is lost.n",city);
}
cntt = temp;
}
if(k==n){
printf("Game Over.n");
}
return 0;
}

方法二:并查集

1
2
3
4
5
6
7
8
9
10
大专栏  L2-013 红色警报(25 分)>11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#include<cmath>
#include<cstdio>
#include<cstring>
using namespace std;
const int maxm = 550;
int n,m;
struct node{
int u,v;
}edge[5005];
int visit[maxm],fa[maxm];
int Find(int x){
if(x==fa[x]){
return fa[x];
}else{
return Find(fa[x]);
}
}
void Union(int x,int y){
int xc = Find(x);
int yc = Find(y);
if(xc!=yc){
fa[xc] = yc;
}
}
int main()
{
int k,u,v;
scanf("%d%d",&n,&m);
for(int i=0;i<n;i++){
fa[i] = i;
}
for(int i=0;i<m;i++){
scanf("%d%d",&u,&v);
edge[i].u = u;
edge[i].v = v;
Union(u,v);
}
int num1 = 0,num2;
for(int i=0;i<n;i++){
if(fa[i]==i){
num1++;
}
}
memset(visit,0,sizeof(visit));
scanf("%d",&k);
for(int j=0;j<k;j++){
num2 = 0;
for(int i=0;i<n;i++){
fa[i] = i;
}
int city;
scanf("%d",&city);
visit[city] = 1;
for(int i=0;i<m;i++){
if(visit[edge[i].u]==1||visit[edge[i].v]==1){
continue;
}else{
Union(edge[i].u,edge[i].v);
}
}
for(int i=0;i<n;i++){
if(fa[i]==i){
num2++;
}
}
if(num1==num2||num1+1==num2){
printf("City %d is lost.n",city);
}else{
printf("Red Alert: City %d is lost!n",city);
}
num1 = num2;
}
num1 = 0;
for(int i=0;i<n;i++){
if(visit[i]==1){
num1++;
}
}
if(num1==n){
printf("Game Over.n");
}
return 0;
}

L2-013 红色警报(25 分)的更多相关文章

  1. L2-013 红色警报 (25分) 并查集复杂度

    代码: 1 /* 2 这道题也是简单并查集,并查集复杂度: 3 空间复杂度为O(N),建立一个集合的时间复杂度为O(1),N次合并M查找的时间复杂度为O(M Alpha(N)), 4 这里Alpha是 ...

  2. L2-013 红色警报 (25 分)

    L2-013 红色警报 (25 分)   战争中保持各个城市间的连通性非常重要.本题要求你编写一个报警程序,当失去一个城市导致国家被分裂为多个无法连通的区域时,就发出红色警报.注意:若该国本来就不完全 ...

  3. L2-013 红色警报 (25 分) (并查集)

    链接:https://pintia.cn/problem-sets/994805046380707840/problems/994805063963230208 题目: 战争中保持各个城市间的连通性非 ...

  4. L2-006 树的遍历 (25 分) (根据后序遍历与中序遍历建二叉树)

    题目链接:https://pintia.cn/problem-sets/994805046380707840/problems/994805069361299456 L2-006 树的遍历 (25 分 ...

  5. PAT 甲级 1020 Tree Traversals (25 分)(二叉树已知后序和中序建树求层序)

    1020 Tree Traversals (25 分)   Suppose that all the keys in a binary tree are distinct positive integ ...

  6. PAT天梯赛练习题 L2-013 红色警报(并查集+逆序加边)

    L2-013. 红色警报 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 战争中保持各个城市间的连通性非常重要.本题要求你编写一 ...

  7. PTA - - 06-图1 列出连通集 (25分)

    06-图1 列出连通集   (25分) 给定一个有NN个顶点和EE条边的无向图,请用DFS和BFS分别列出其所有的连通集.假设顶点从0到N-1N−1编号.进行搜索时,假设我们总是从编号最小的顶点出发, ...

  8. 天梯赛决赛 L2-1.红色警报 并查集

    L2-013. 红色警报 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 战争中保持各个城市间的连通性非常重要.本题要求你编写一 ...

  9. 中国大学MOOC-陈越、何钦铭-数据结构-2015秋 01-复杂度2 Maximum Subsequence Sum (25分)

    01-复杂度2 Maximum Subsequence Sum   (25分) Given a sequence of K integers { N​1​​,N​2​​, ..., N​K​​ }. ...

随机推荐

  1. R 画地图

    R 绘制中国省市分布地图 library(maps) library(mapdata) library(maptools); getColor=function(mapdata,provname,pr ...

  2. org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'socialCode' in 'class java.lang.String'

    异常: org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.reflection.Refl ...

  3. 1)PHP基础介绍

    1.php基础介绍: Perssonal Home Page  ====>PHP 2.应用范围 · web服务器脚本语言 命令行脚本语言     应用程序图形界面 3.PHP运行环境 PHP解释 ...

  4. java去掉数字后面的0

    有些财务业务场景是需要把数字多余的0去掉的. 可以这么写 private String getRealData(BigDecimal num) { if (num == null) { return ...

  5. 第04项目:淘淘商城(SpringMVC+Spring+Mybatis) 的学习实践总结【第五天】

    https://pan.baidu.com/s/1bptYGAb#list/path=%2F&parentPath=%2Fsharelink389619878-229862621083040 ...

  6. Java实现卖票程序(两种线程实现)

    /** * 2019年8月8日16:05:05 * 目的:实现火车站卖票系统(第一种创建线程的方式) * @author 张涛 * */ //第一种方式直接继承Thread来创建线程 class T1 ...

  7. ThreadPoolExecutor自定义线程池

    1.ThreadPoolExecutor创建线程池的构造函数 public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long ...

  8. Java分层架构的使用规则

    原文章引用地址:http://blog.csdn.net/ygzk123/article/details/7816511 三层结构的程序不是说把项目分成DAL, BLL, WebUI三个模块就叫三层了 ...

  9. 现有.NET 开源框架浅析

    自己一直在关注框架,也喜欢捣鼓一些框架,最近我们自己一直是在用OSGI.NET 做插件式模块开发,感兴趣的可以到 http://www.iopenworks.com/   官网了解,在进行OSGI.N ...

  10. Python的range(n)的用法

    Python的range(n) 方法就是: API定义: If you do need to iterate(迭代) over a sequence(一系列) of numbers, the buil ...