3025: 【普及/提高-】【P1536】村村通
内存限制:128 MB
时间限制:1.000 S
评测方式:文本比较
命题人:
提交:3
解决:2
题目描述
某市调查城镇交通状况,得到现有城镇道路统计表。表中列出了每条道路直接连通的城镇。市政府 "村村通工程" 的目标是使全市任何两个城镇间都可以实现交通(但不一定有直接的道路相连,只要相互之间可达即可)。请你计算出最少还需要建设多少条道路?
输入
输入包含若干组测试数据,每组测试数据的第一行给出两个用空格隔开的正整数,分别是城镇数目 和道路数目 ;随后的 行对应 条道路,每行给出一对用空格隔开的正整数,分别是该条道路直接相连的两个城镇的编号。简单起见,城镇从 到 编号。
注意:两个城市间可以有多条道路相通。
在输入数据的最后,为一行一个整数 ,代表测试数据的结尾。
输出
对于每组数据,对应一行一个整数。表示最少还需要建设的道路数目。
样例输入 复制
4 2
1 3
4 3
3 3
1 2
1 3
2 3
5 2
1 2
3 5
999 0
0
样例输出 复制
1
0
2
998
提示
数据规模与约定
对于 的数据,保证 。
有n个点,m条边,组成k个集合,最少需要k-1条线能将集合互相连通。
1. 读入数据
2. 将点聚合成集合
3. 统计集合的个数
4.集合个数-1就是答案
#include<bits/stdc++.h> using namespace std; int n,m,fa[100005],x,y,cnt; int find(int x) { if (fa[x]==x) return x; else return fa[x]=find(fa[x]); } void join(int c1,int c2) { int f1=find(c1),f2=find(c2); if (f1!=f2) fa[f1]=f2; } int main(){ while (1) { cin>>n; if (n==0) { return 0; } cin>>m; for (int i=1;i<=n;i++) fa[i]=i; for (int i=1;i<=m;i++) { cin>>x>>y; join(x,y); } cnt=0; for (int i=1;i<=n;i++) if (fa[i]==i) cnt++; cout<<cnt-1<<endl; } return 0; }