社区讨论

求调(玄关)

灌水区参与者 5已保存回复 6

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
6 条
当前快照
1 份
快照标识符
@m6vz6rri
此快照首次捕获于
2025/02/08 17:10
去年
此快照最后确认于
2025/11/04 09:43
4 个月前
查看原帖
CPP
#include<iostream>
using namespace std;
int n,m;
int e[1010];
int fa[1010];
int find(int x)
{
	if(x==fa[x]) return fa[x];
	else return fa[x]=find(fa[x]);
}
		char c;
		int a,b;
		int f_a,f_b;
int main()
{
	cin>>n>>m;
	for(int i=1;i<=n;i++) fa[i]=i;
	for(int i=1;i<=m;i++)
	{
		cin>>c>>a>>b;
		f_a=find(a),f_b=find(b);
		if(c=='F')
		{
			fa[f_a]=f_b;
		}
		else
		{
			if(!e[a]) e[a]=f_b;
			else fa[f_b]=e[a];
			if(!e[b]) e[b]=f_a;
			else fa[f_a]=e[b];
		}
	}
	int ans=0;
	for(int i=1;i<=n;i++)
	{
		if(fa[i]!=i) ans++;
	}
	cout<<n-ans;
}

回复

6 条回复,欢迎继续交流。

正在加载回复...