WA代码
#include <bits/stdc++.h>
using namespace std;
char p;
int fa[2005];
int Find(int x){
return x==fa[x]?x:fa[x]=Find(fa[x]);
}
void unite(int x,int y){
fa[Find(x)]=Find(y);
}
int main()
{
int n,m,/*p,*/u,v;
cin>>n;cin>>m;
for(int i=1;i<=n*2;i++) fa[i]=i;
while(m--){
cin>>p>>u>>v;
if(p==/*0*/'F'){
unite(u,v);
//unite(u+n,v+n);
}
else {
unite(u,v+n);
unite(u+n,v);
}
}
int ans=0;
for(int i=1;i<=n;i++) if(Find(i)==i) ans++;
cout<<ans<<endl;
return 0;
}
AC代码
#include<bits/stdc++.h>
#define r(i,a,b) for(int i=a;i<=b;i++)
using namespace std;
int f[2002],n,m,a,b,ans;char c;
bool tong[1001];
struct BCJ{/*并查集,自己弄得几个函数,dalao勿喷。。。*/
void start(int x)//初始化
{r(i,1,x) f[i]=i;}
int find(int x)//查找
{return x==f[x]?x:f[x]=find(f[x]);}
void judge(int a,int b)//合并
{f[find(a)]=find(b);}
bool too(int a,int b)//判断两个元素是否在同一集合
{return find(a)==find(b);}
}acs;
int main()
{
cin>>n;
acs.start(n*2);//初始化
cin>>m;
r(i,1,m)
{
cin>>c>>a>>b;
if(c=='E')//敌对关系
{
acs.judge(b+n,a);//合并
acs.judge(a+n,b);//合并
}
else
acs.judge(a,b);//合并
}
r(i,1,n)
{if(f[i]==i)ans++;}//求一共有几种
cout<<ans;
}
呼救呼救呼救呼救