简单并查集 -- HDU 1232 UVALA 3644 HDU 1856

时间:2022-09-05 14:30:00

并查集模板:

 #include<iostream>
using namespace std;
int Rank[],x,y;
int v[];
//初始化 x 集合
void init(int n)
{
for(int i=; i<n; i++)
{
v[i]=i;
Rank[i]=;
}
}
//查找 x 所在的集合
int find_set(int x)
{
if(v[x]!=x) v[x]=find_set(v[x]);
return v[x];
}
///更新根节点,有可能会暴栈
int mix(int x,int y)
{
int fx,fy;
fx=find_set(x);
fy=find_set(y);
if(fx!=fy)
p[fx]=fy;
}
//合并 x, y 所在的集合,用到路径压缩,按秩合并
void Union(int x,int y)
{
x=find_set(x);
y=find_set(y);
if(Rank[x]>Rank[y])
v[y]=x;
else if(Rank[x]<Rank[y])
v[x]=y;
else if(Rank[x]==Rank[y])
{
v[x]=y;
Rank[y]++;
}
}
int main()
{
return ;
}

模板

计算环的个数,需要缩点:

 #include <iostream>
#include <cmath>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <string>
#include <sstream>
#include <algorithm>
#define maxn 100010
#define INF 0x7fffffff
#include <queue>
#define N 1000010
#define ll __int64
#define mem(a,b) memset(a,b,sizeof(a))
#define repu(i, a, b) for(int i = (a); i < (b); i++)
const double PI=-acos(-1.0);
using namesPce std;
///初始化 x 集合
int P[maxn],Rank[maxn];
void mix()
{
repu(i,,maxn)
{
P[i]=i;
Rank[i]=;
}
}
///查找 x 所在的集合
int find_set(int x)
{
if(P[x]!=x)
P[x]=find_set(P[x]);
return P[x];
}
///缩点,合并 x, y 所在的集合,用到路径压缩,按秩合并
void Union(int x,int y)
{
x=find_set(x);
y=find_set(y);
if(Rank[x]>Rank[y])
P[y]=x;
else if(Rank[x]<Rank[y])
P[x]=y;
else if(Rank[x]==Rank[y])
{
P[x]=y;
Rank[y]++;
}
}
int main()
{
int x,y;
while(scanf("%d",&x) == )
{
mix();
int refu = ;
while(x!=-)
{
scanf("%d",&y);
x = find_set(x);
y = find_set(y);
if(x == y)///如果同一个根节点,就是环
++refu;
else
Union(x,y);
scanf("%d",&x);
}
printf("%d\n",refu);
}
return ;
}

UVALA3644 find_set + Union

计算联通块的个数

题意:n个结点,m条边,求再连几条边能使得全部结点连通;

思路:并查集,求该图中有几个连通分支,然后连通块的个数-1;

 #include<iostream>
#include<string>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<cmath>
using namespace std;
int p[];
int n,m;
int a,b;
int find_set(int x)
{
return p[x]==x?x:find_set(p[x]);
}
void mix(int x,int y)
{
int fx,fy;
fx=find_set(x);
fy=find_set(y);
if(fx!=fy)
p[fx]=fy;
}
int main()
{
int cas=;
while(scanf("%d",&n)&&n)
{
scanf("%d",&m);
int count=;
for(int i=; i<=n; i++)
p[i]=i;
for(int j=; j<=m; j++)
{
scanf("%d%d",&a,&b);
mix(a,b);
}
for(int i=; i<=n; i++)
if(p[i]==i) count++;
printf("%d\n",count-);
}
return ;
}

HDU 1232 find_set + mix

计算每个连通块个数,取最大:

 #include<cstdio>
#include <cstring>
#include <cstdlib>
#include <algorithm>
using namespace std;
struct A
{
int num,pre;
} Set[];
void init(int n)///初始化
{
int i;
for(i=; i<=n; i++)
{
Set[i].num=;
Set[i].pre=i;
}
}
int Find(int k)///找根节点
{
if(Set[k].pre==k)
return k;
return Set[k].pre = Find(Set[k].pre);
}
int main()
{
int n,maxn,ans,i,f1,f2;
int x[],y[];
while(~scanf("%d",&n))
{
if(n==)
{
printf("1\n");
continue;
}
maxn=;
for(i=; i<=n; i++)
{
scanf("%d%d",&x[i],&y[i]);
maxn = max(maxn,max(x[i],y[i]));
}
init(maxn);
for(i=; i<=n; i++)
{
f1=Find(x[i]);
f2=Find(y[i]);
if(f1!=f2)
{
Set[f1].pre=f2;
Set[f2].num += Set[f1].num;///把该节点的子节点加上
}
}
ans=;
for(i=; i<=maxn; i++)
ans=max(ans,Set[i].num);
printf("%d\n",ans);
}
return ;
}

HDU 1856 find_set

简单并查集 -- HDU 1232 UVALA 3644 HDU 1856的更多相关文章

  1. 1213 How Many Tables(简单并查集)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1213 简单并查集,统计单独成树的数量. 代码: #include <stdio.h> #i ...

  2. POJ 2524 &lpar;简单并查集&rpar; Ubiquitous Religions

    题意:有编号为1到n的学生,然后有m组调查,每组调查中有a和b,表示该两个学生有同样的宗教信仰,问最多有多少种不同的宗教信仰 简单并查集 //#define LOCAL #include <io ...

  3. poj1611 简单并查集

    The Suspects Time Limit: 1000MS   Memory Limit: 20000K Total Submissions: 32781   Accepted: 15902 De ...

  4. 【简单并查集】Farm Irrigation

    Farm Irrigation Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Tot ...

  5. ACM&lowbar;&OpenCurlyDoubleQuote;打老虎”的背后(简单并查集)

    “打老虎”的背后 Time Limit: 2000/1000ms (Java/Others) Problem Description: “习大大”自担任国家主席以来大力反腐倡廉,各地打击贪腐力度也逐步 ...

  6. hdu 2480 贪心&plus;简单并查集

    Steal the Treasure Time Limit: 10000/6000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Othe ...

  7. poj1988 简单并查集

    B - 叠叠乐 Crawling in process... Crawling failed Time Limit:2000MS     Memory Limit:30000KB     64bit ...

  8. UVA - 1197 (简单并查集计数)

    Severe acute respiratory syndrome (SARS), an atypical pneumonia of unknown aetiology, was recognized ...

  9. poj 2524 Ubiquitous Religions 一简单并查集

    Ubiquitous Religions   Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 22389   Accepted ...

随机推荐

  1. RabbitMQ学习系列(五)&colon; RPC 远程过程调用

    前面讲过一些RabbitMQ的安装和用法,也说了说RabbitMQ在一般的业务场景下如何使用.不知道的可以看我前面的博客,http://www.cnblogs.com/zhangweizhong/ca ...

  2. pip常见操作收录

    由于这些东西比较容易忘掉,在这里几下吧 1. pip 对应用进行安装: sudo pip install  your_app 2. pip 对应用进行update sudo pip install   ...

  3. hdu 1231&comma; dp &comma;maximum consecutive sum of integers&comma; find the boundaries&comma; possibly all negative&comma; C&plus;&plus; 分类: hdoj 2015-07-12 03&colon;24 87人阅读 评论&lpar;0&rpar; 收藏

    the algorithm of three version below is essentially the same, namely, Kadane's algorithm, which is o ...

  4. bzoj1188 &lbrack;HNOI2007&rsqb;分裂游戏 博弈论 sg函数的应用

    1188: [HNOI2007]分裂游戏 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 973  Solved: 599[Submit][Status ...

  5. Android SDK Manager 设置代理

    直接启用 Android SDK Manager 的命令如下: 在SDK 的 tools 目录下执行: ./android sdk 就会进入 Android SDK Manager   设置代理 在 ...

  6. sql server 安装后登录服务器

    计算机名\数据库实例名 z*******f-PC\zzf

  7. 《Genesis-3D开源游戏引擎完整实例教程-2D射击游戏篇01:播放序列动画》

    1.播放序列动画 系列动画播放概述 2D游戏中的动画系统,不同于3D游戏.3D游戏中,角色美术资源不仅包含角色模型的,还包括角色的贴图和动作等,模型本身自带角色的动作动画效果.2D游戏中,角色美术资源 ...

  8. puppet证书重申

  9. 笔记react router 4(二)

    上一篇我们提到react router 4的dom特性.那么这一次,我们来说一说4.X中的路由组件嵌套. 用过3.X的同学应该知道,路由组件的嵌套(即,路由的配置)方式是通过给<Route&gt ...

  10. 删数问题(NOI94)

    删数问题(NOI94) 输入一个高精度的正整数N,去掉其中任意S个数字后剩下的数字按原左右次序组成一个新的正整数.编程对给定的N和S,寻找一种方案使得剩下的数字组成的新数最小.输出新的正整数.(N不超 ...