比赛 20160902 评测结果 AAAAAAAATA
题目名称 宗教信仰 最终得分 90
用户昵称 Arrow 运行时间 1.480 s
代码语言 C++ 内存使用 0.51 MiB
提交时间 2016-09-02 19:33:29
显示代码纯文本
#include<iostream>
#include<fstream>
using namespace std;
int a[50001]={0};
int find(int x){
	if(a[x]==x) return x;
	a[x]=find(a[x]);
	return a[x];
}
void merge(int x,int y){
	int xx=find(x);
	int yy=find(y);
	a[xx]=yy;
}
int main()
{
	ifstream fin("religion.in");
	ofstream fout("religion.out");
	int m,n,s1,s2,ans=0;
	fin>>n;
	fin>>m;
	for(int i=1;i<=n;i++)
		a[i]=i;
	for(int i=0;i<m;i++){
		fin>>s1;
		fin>>s2;
		merge(s1,s2);
	}
	for(int i=1;i<=n;i++){
		if(a[i]==i)
			ans++;
	}
	fout<<ans<<endl;
	fin.close();
	fout.close();
return 0;
}