暢通工程
Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 12689 Accepted Submission(s): 6499
注意:兩個城市之間可以有多條道路相通,也就是說
3 3
1 2
1 2
2 1
這種輸入也是合法的
當N爲0時,輸入結束,該用例不被處理。
#include<iostream>
#include<set>
using namespace std;
int UFSet[1001];
int m,n;
int find(int i){
return UFSet[i];
}
void init(){
for(int i=0;i<n;i++){
UFSet[i]=i;
}
}
void merge(int x,int y){
int a,b;
a=min(UFSet[x],UFSet[y]);
b=max(UFSet[x],UFSet[y]);
for(int i=0;i<n;i++){
if(UFSet[i]==b)
UFSet[i]=a;
}
}
int main(){
set<int> s;
int x,y;
while(cin>>n,n>0){
cin>>m;
init();
for(int i=0;i<m;i++){
cin>>x>>y;
merge(x-1,y-1);
}
s.clear();
for(int i=0;i<n;i++){
s.insert(find(i));
}
cout<<s.size()-1<<endl;
}
return 0;
}