算法练习之并查集(路径压缩)

无你想你 2023-03-09 23:00:44

#include<iostream>
using namespace std;
const int N=100010;
int n,m;
int p[N],size[N];
 
int find(int x)//这里实现了路径压缩
{
    if(p[x]!=x)p[x]=find(p[x]);
    return p[x]; 
}
int main()
{
    scanf("%d%d",&n,&m);
    for(int i=1;i<n;++i)
    {
        p[i]=i;
        size[i]=1;
    }
    while(m--)
    {
        char op[5];
        int a,b;
        scanf("%s",op);
        if(op[0]=='C')
        {
            scanf("%s",op);
            if(find(b)==find(a))continue;
            size[find(b)]+=size[find(a)];
            p[find(a)]=find(b);
        }
        else if(op[1]=='1')
        {
            scanf("%d%d",&a,&b);
            if(find(a)==find(b))puts("Yes");
            else puts("No");
        }
        else
        {
            scanf("%d",&a);
            printf("%d\n",size[find(a)]);
        }
    }
    return 0;
}

...全文
239 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
无你想你 2023-04-06
  • 打赏
  • 举报
回复

#include
using namespace std;
const int N=100010;
int p[N],cnt[N];

int find(int x)
{
// 寻找父节点
if(p[x]!=x)p[x]=find(p[x]);
return p[x];
}
void Union(int a,int b)
{
int pa=find(a),pb=find(b);
if(pa!=pb)
{
cnt[pb]+=cnt[pa];//把pa中连通块的个数加入到pb中
p[pa]=pb;
}

}

int main()
{
int n,m;
cin>>n>>m;
for(int i=1;i<=n;++i)p[i]=i,cnt[i]=1;

while(m--)
{
    string op;
    int a,b;
    cin>>op;
    
    if(op=="C")
        {
            cin>>a>>b;
            Union(a,b);
        }
    else if(op=="Q1")
        {
            cin>>a>>b;
            if(find(a)==find(b))puts("Yes");
            else puts("No");
        }
    else
    {
     cin>>a;
     cout<<cnt[find(a)]<<endl;
    }
}
return 0;

}

30,386

社区成员

发帖
与我相关
我的任务
社区描述
打造最热爱学习的高校社区,帮助大家提升计算机领域知识,带大家打比赛拿奖,提高自我,希望大家共同创造良好的社区氛围。
社区管理员
  • 川川菜鸟
  • 亡心灵
  • 星辰菜鸟
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

监督大家学习,每日学习打卡,以投稿形式打卡。扫码关注公众号,可加入粉丝群和领取大量资源。

试试用AI创作助手写篇文章吧