7-34 红色警报 (10 分)

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

结尾无空行

三刷、满分代码

#include<bits/stdc++.h>
using namespace std;
#define N 510
#define M 5010
int n ,m ,k ,vis[N] ,p[N];
struct node {int x;int y;
}g[M];
int find(int x) {if (x != p[x]) p[x] = find(p[x]);return p[x];
}
int main() {cin >> n >> m;for (int i = 0; i < n; i++) p[i] = i;for (int i = 0; i < m; i++) {cin >> g[i].x >> g[i].y;if (find(g[i].x) != find(g[i].y))p[find(g[i].x)] = find(g[i].y);}int cnt1 = 0;for (int i = 0; i < n; i++) {if (p[i] == i) cnt1 ++;}cin >> k;for (int j = 0; j < k; j++) {int x ,cnt2 = 0;cin >> x;vis[x] = 1;for (int i =0 ; i < n; i++) p[i] = i;for (int i = 0; i < m; i++) {if (vis[g[i].x] == 1 ||vis[g[i].y] == 1) continue;if (find(g[i].x) != find(g[i].y))p[find(g[i].x)] = find(g[i].y);}for (int i = 0; i < n; i++) {if (p[i] == i)cnt2++;}if (cnt2 - cnt1 > 1) printf ("Red Alert: City %d is lost!\n" ,x);else printf ("City %d is lost.\n" ,x);cnt1 = cnt2;}if (k >= n) cout << "Game Over.\n";return 0;
}

两分的代码

#include<iostream>
using namespace std;
const int N=510,M=10010;
int n,m,k,cnt1,cnt2,c;
int p[N],vis[N];
int find(int x){if(x!=p[x])p[x]=find(p[x]);return p[x];
}
void add(int x,int y){x=find(x);y=find(y);p[x]=y;
}
struct ll{int c1,c2;
}s[M];
int main(){cin>>n>>m;for(int i=0;i<n;i++)p[i]=i;for(int i=0;i<m;i++){cin>>s[i].c1>>s[i].c2;add(s[i].c1,s[i].c2);}for(int i=0;i<n;i++)if(p[i]==i)cnt1++;cin>>k;for(int i=0;i<k;i++){cin>>c;for(int j=0;j<n;j++)p[j]=j;vis[c]=1;for(int j=0;j<m;j++){if(vis[s[j].c1]==1||vis[s[j].c2]==1)continue;add(s[j].c1,s[j].c2);}cnt2=0;for(int j=0;j<n;j++)if(p[j]==j)cnt2++;if(cnt2-1==cnt1||cnt2==cnt1)cout<<"City "<<c<<" is lost."<<endl;else cout<<"Red Alert: City "<<c<<" is lost!"<<endl;cnt1=cnt2;}if(k>=n)cout<<"Gream Over."<<endl;return 0;
}
#include<iostream>
using namespace std;int father[501];
int N,M;
int visit[501]; struct data{//记道路int x;int y;
};int find(int x){while(father[x] != x){x = father[x];}return x;
}void add(int x,int y){int x1 = find(x);int y1 = find(y);if(x1 != y1){father[x1] = y1;}
}int main(){cin>>N>>M;int a,b;struct data node [M];for(int i=0;i<N;i++){father[i] = i;}for(int i=0;i<M;i++){cin>>a>>b;node[i].x = a;node[i].y = b;add(a,b);//合并节点,将可以连通的节点合并}int num1 = 0;for(int i=0;i<N;i++){if(father[i] == i){num1++;//统计块的个数}}int K;cin>>K;int n;for(int j=0;j<K;j++){cin>>n;//重新计算numfor(int i=0;i<N;i++){father[i] = i;}visit[n] = 1;//这个数组的作用是,标记删除过的节点for(int i=0;i<M;i++){if(visit[node[i].x] == 1 || visit[node[i].y] == 1){continue;//结束本次循环,进行下次循环}add(node[i].x,node[i].y);//合并没有被删除过的节点}int num2 = 0;for(int i=0;i<N;i++){if(father[i] == i){num2++;}}if(num2-1 == num1 || num2 == num1){cout<<"City "<<n<<" is lost."<<endl;}else{cout<<"Red Alert: City "<<n<<" is lost!"<<endl;}num1 = num2;}if(K >= N)cout<<"Game Over."<<endl;return 0;
}

7-34 红色警报 (10 分)(结构体并查集)相关推荐

  1. 【CCCC】L2-013 红色警报 (25分),,并查集计算集合个数

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

  2. C++学习之路 | PTA(天梯赛)—— L2-013 红色警报 (25分)(带注释)(并查集)(精简)

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

  3. R7-9 红色警报 (25 分)

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

  4. 3-4 计算个人所得税 (10分)

    3-4 计算个人所得税 (10分) 假设个人所得税为:税率×(工资−1600).请编写程序计算应缴的所得税,其中税率定义为: 当工资不超过1600时,税率为0: 当工资在区间(1600, 2500]时 ...

  5. 第10章结构体01——结构体字节大小的计算

    1.该篇笔记详见C提高笔记(传智播客) 文章目录 博文01:(常考面试题) 三步解决C语言中struct字节对齐问题,结构体的字节大小问题 第1步.先确定结构体实际对齐单位, 第2步.除结构体的第一个 ...

  6. 红色警报 (25 分)【测试点分析】【两种解法】

    立志用最少的代码做最高效的表达 战争中保持各个城市间的连通性非常重要.本题要求你编写一个报警程序,当失去一个城市导致国家被分裂为多个无法连通的区域时,就发出红色警报.注意:若该国本来就不完全连通,是分 ...

  7. C++学习之路 | PTA(天梯赛)—— L3-003 社交集群 (30分) (带注释) (并查集) (精简)

    L3-003 社交集群 (30分) 当你在社交网络平台注册时,一般总是被要求填写你的个人兴趣爱好,以便找到具有相同兴趣爱好的潜在的朋友.一个"社交集群"是指部分兴趣爱好相同的人的集 ...

  8. 【CCCC】L2-024 部落 (25分),,并查集,模板水题,统计集合个数

    problem L2-024 部落 (25分) 在一个社区里,每个人都有自己的小圈子,还可能同时属于很多不同的朋友圈.我们认为朋友的朋友都算在一个部落里,于是要请你统计一下,在一个给定社区中,到底有多 ...

  9. 7-11 家庭房产(25 分) 【并查集】

    7-11 家庭房产(25 分) 给定每个人的家庭成员和其自己名下的房产,请你统计出每个家庭的人口数.人均房产面积及房产套数. 输入格式: 输入第一行给出一个正整数N(≤1000),随后N行,每行按下列 ...

最新文章

  1. 复制类中的属性值到另一个类的相同属性中
  2. 小米手机反复提示“请勿遮挡听筒区域“
  3. semaphore的使用
  4. IntelliJ IDEA for Windows 默认模式下的快捷键
  5. c语言math函数 sgn,常用矩阵计算C语言代码
  6. Python面试总结(四)ip正则与三次握手四次挥手
  7. centos5.5和6.5中vncservervncviewer最基本配置
  8. 运行iphone模拟器
  9. 传奇服务器赞助文件夹,传奇服务端每个文件夹的含义
  10. 获得商品详情-京东api接口
  11. linux usb gadget 日志
  12. 熬了一夜!我用Python做了一个网站,帮小姐姐生成漫画头像
  13. 【问题解决】Springboot中@Value()读取不到配置文件属性解决方法
  14. NOIP2017普及组初赛试题及答案
  15. 又是一年总结时-2007年总结及2008年计划
  16. 关于MFC的使用总结之八——CGridListCtrlEx鼠标响应事件
  17. 分享Silverlight/Windows8/WPF/WP7/HTML5周学习导读(6月11日-6月17日)
  18. mc服务器 领地插件配置文件,Residence插件 领地插件 | 我的世界 | MC世界侠
  19. ubuntu 如何在终端下切换到指定的文件夹或盘根目录
  20. c++ hls协议 m3u8解析器

热门文章

  1. 信安教程第二版-第8章防火墙技术原理与应用
  2. Windows三十年进化史,从Windows 1.0到Windows 10
  3. 华为鸿蒙系统学习笔记9-华为鸿蒙OS与LiteOS对比
  4. android命令打包,android 命令打包
  5. python D14 内置函数二
  6. JAVA基础知识总结:二十一
  7. C程序范例(2)——学生管理系统”链表“实现
  8. 大蚂蚁在64位系统下,右键没有快发的解决方案
  9. 介绍org.eclipse.core.runtime中工具类
  10. Mr.J--谈谈CSS和Html(font)