改得跟能AC的题解几乎一模一样,可……
查看原帖
改得跟能AC的题解几乎一模一样,可……
300078
pengyule楼主2020/7/16 10:09
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;
}

呼救呼救呼救呼救

2020/7/16 10:09
加载中...