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. 创建Maven项目时Maven中的GroupID和ArtifactID的意思

    GroupID 是项目组织中唯一的标识符,对应Java包结构,在项目中看到的是main目录里java的目录结构. ArtifactID是项目的唯一的标识符,实际对应项目的名称(就是idea中工程的名字 ...

  2. 吴裕雄--天生自然 pythonTensorFlow图形数据处理:windows操作系统安装指定版本的tensorflow

    pip install tensorflow==1.14.0

  3. 天融信(NAT)地址转换端口映射配置

    目的地址为公司的公网地址 服务:选择或者自己定义一个端口号,就是要映射到服务器上的那个端口号 目的地址转换为:服务器ip 目的端口转换为:选择定义的服务(端口号) 规则描述:随便写

  4. Opencv笔记(十二)——形态学转换

    学习目标: 学习不同的形态学操作,例如腐蚀,膨胀,开运算,闭运算等 我们要学习的函数有: cv2.erode(), cv2.dilate(), cv2.morphologyEx()等 原理简介: 形态 ...

  5. layui 触发 select 下option 被选择事件

    1.找到值为某一个的元素 var S0 = 'dd[lay-value='+ level+']'; 2.给该元素注册点击事件  siblings(兄弟节点) $('select[name=\'leve ...

  6. Linux基础篇六:Linux文件属性和类型

    -:代表文件 s: sorket文件 b:block块设备 (磁盘,光驱等) c:字符设备 l:连接文件 p:管道文件 d:代表目录文件 为了更加区分- (文件的具体类型),系统提供了file命令更加 ...

  7. android流式布局、待办事项应用、贝塞尔曲线、MVP+Rxjava+Retrofit、艺术图片应用等源码

    Android精选源码 android模仿淘宝首页效果源码 一款艺术图片应用,采用T-MVVM打造 Android MVP + RxJava + Retrofit项目 android流式布局实现热门标 ...

  8. B 小雨的三角形

    题目链接:https://ac.nowcoder.com/acm/contest/949/B 思路: 一个找规律题,找到规律就很简单,只剩下代码实现了.规律:第i行去头尾剩下的数的和等于第i-1行去头 ...

  9. git本地仓库目录问题

    git安装后修改默认的路径:每次打开git bash后都会进入这个目录 https://blog.csdn.net/weixin_39634961/article/details/79881140 在 ...

  10. Django环境的搭建以及最简示例

    一.环境的搭建 先安装pip yum install python-pip 安装失败: 安装epel扩展源 yum install epel-release 在安装pip 再利用pip安装django ...