并查集

并查集(Union-find Sets)是一种非常精巧而实用的数据结构,它主要用于处理一些不相交集合的合并问题。一些常见的用途有:求连通子图、求最小生成树的Kruskal算法和求最近公共祖先(LCA)等。

并查集的基本操作

  • 1.初始化init
  • 2.查询find
  • 3.合并unionn
//用数组fa[]来存储每个元素的父节点
int fa[MAXN];
//一开始,我们先将它们的父节点设为自己
void init(int n)
{
for(int i=1;i<=n;i++)
fa[i]=i;
}
//查询 找到i的祖先就返回
int find(int i)
{
if(fa[i]==i) return i; //递归出口,当到达了祖先位置,就返回祖先
else
{
fa[i]=find(fa[i]); //路径压缩
return findfa[i]; //不断向上查找祖先
} }
void unionn(int i,int j)
{
int i_fa=find(i);
int j_fa=find(j);
fa[i_fa]=j_fa; //i的祖先指向j的祖先
}

亲戚

P1551 亲戚 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

题目背景

若某个家族人员过于庞 大,要判断两个是否是亲戚,确实还很不容易,现在给出某个亲戚关系图,求任意给出的两个人是否具有亲戚关系。

题目描述

规定:xy 是亲戚,yz 是亲戚,那么 xz 也是亲戚。如果 xy 是亲戚,那么 x 的亲戚都是 y 的亲戚,y 的亲戚也都是 x 的亲戚。

输入格式

第一行:三个整数 n,m,p,(n,m,p≤5000),分别表示有 n 个人,m* 个亲戚关系,询问 p 对亲戚关系。

以下 m 行:每行两个数 i j,表示 i 和 j 具有亲戚关系。

接下来 p 行:每行两个数 P_i,P_j,询问 P_i和 P_j 是否具有亲戚关系。

输出格式

p 行,每行一个 YesNo。表示第 i 个询问的答案为“具有”或“不具有”亲戚关系。

输入输出样例

输入 #1复制

6 5 3
1 2
1 5
3 4
5 2
1 3
1 4
2 3
5 6

输出 #1复制

Yes
Yes
No
#include<iostream>
using namespace std;
#define MAXN 20001
int fa[MAXN];
//一开始,我们先将它们的父节点设为自己
void init(int n)
{
for (int i = 1; i <= n; i++)
fa[i] = i;
}
//查询 找到i的祖先就返回
int find(int i)
{
if (fa[i] == i) return i; //递归出口,当到达了祖先位置,就返回祖先
else
{
fa[i] = find(fa[i]); //路径压缩
return fa[i]; //不断向上查找祖先
} }
void unionn(int i, int j)
{
int i_fa = find(i);
int j_fa = find(j);
fa[i_fa] = j_fa; //i的祖先指向j的祖先
} int main()
{
int n, m, x, y, q;
cin >> n;
init(n);
cin >> m;
for (int i = 0; i < m; i++)
{
cin >> x >> y;
unionn(x, y);
}
cin >> q;
for (int i = 0; i < q; i++)
{
cin >> x >> y;
if (find(x) == find(y))
cout << "Yes" << endl;
else cout << "No" << endl;
}
return 0;
}

任意点

任意点 (nowcoder.com)

题意

平面上有若干个点,从每个点出发,你可以往东南西北任意方向走,直到碰到另一个点,然后才可以改变方向。

请问至少需要加多少个点,使得点对之间互相可以到达。

输入描述

第一行一个整数n表示点数( 1 <= n <= 100)。

第二行n行,每行两个整数xi, yi表示坐标( 1 <= xi, yi <= 1000)。

y轴正方向为北,x轴正方形为东。

输出描述

输出一个整数表示最少需要加的点的数目。

解析

这个题目不难,也是一个裸的并查集,不过有一点隐晦,下面解释一下。

首先他只能撞到一个点才能停,看这个图

可以看到1234都是可以相互联系的,而5是独立出来的一个点,要是想要到达5,就要在12或者24之间加一个点,所以这个像什么,就是两个独立的连通块,这样子就很明显是一个并查集了。

这个并查集是当x相同或者y相同的时候,就可以插入在一个块里面。

#include <iostream>
using namespace std; struct point {
int x;
int y;
} p[110];
int fa[110]; int find(int x) {
if (fa[x] == x)
return x;
fa[x] = find(fa[x]);
return fa[x];
} void join(int x, int y) {
int fx = find(x);
int fy = find(y);
fa[fx] = fy;
} int main() {
int n;
cin >> n;
for (int i = 1; i <= n; ++i) {
fa[i] = i;
cin >> p[i].x >> p[i].y; //scanf("%d")
}
for (int i = 2; i <= n; ++i) {
for (int j = 1; j < i; ++j) {
if (p[i].x == p[j].x || p[i].y == p[j].y) {
join(i, j);
}
}
}
int ans = -1;
for (int i = 1; i <= n; ++i) {
if (fa[i] == i)
++ans;
}
cout << ans << endl;
return 0;
}

【ACM程序设计】并查集的更多相关文章

  1. ACM数据结构-并查集

    ACM数据结构-并查集   并查集,在一些有N个元素的集合应用问题中,我们通常是在开始时让每个元素构成一个单元素的集合,然后按一定顺序将属于同一组的元素所在的集合合并,其间要反复查找一个元素在哪个集合 ...

  2. ACM: The Suspects-并查集-解题报告

    The Suspects Time Limit:1000MS Memory Limit:20000KB 64bit IO Format:%lld & %llu Description 严重急性 ...

  3. acm专题--并查集

    题目来源:http://hihocoder.com/problemset/problem/1066 #1066 : 无间道之并查集 时间限制:20000ms 单点时限:1000ms 内存限制:256M ...

  4. ACM: Ubiquitous Religions-并查集-解题报告

    Ubiquitous Religions Time Limit:5000MS Memory Limit:65536KB 64bit IO Format:%lld & %llu Descript ...

  5. ACM学习历程—SNNUOJ 1110 传输网络((并查集 && 离线) || (线段树 && 时间戳))(2015陕西省大学生程序设计竞赛D题)

    Description Byteland国家的网络单向传输系统可以被看成是以首都 Bytetown为中心的有向树,一开始只有Bytetown建有基站,所有其他城市的信号都是从Bytetown传输过来的 ...

  6. HDU 6109 数据分割 【并查集+set】 (2017"百度之星"程序设计大赛 - 初赛(A))

    数据分割 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  7. HDU 5458 Stability(双连通分量+LCA+并查集+树状数组)(2015 ACM/ICPC Asia Regional Shenyang Online)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5458 Problem Description Given an undirected connecte ...

  8. 2019西北工业大学程序设计创新实践基地春季选拔赛 I Chino with Rewrite (并查集+树链剖分+线段树)

    链接:https://ac.nowcoder.com/acm/contest/553/I 思路:离线整棵树,用并查集维护下联通的情况,因为值只有60个,用2的x(1<=x<=60)次方表示 ...

  9. TOJ3955: NKU ACM足球赛(并查集+map+细节题)

    时间限制(普通/Java):5000MS/15000MS     内存限制:65536KByte 描述 NKU ACM最近要举行足球赛,作为此次赛事的负责人,Lee要对报名人员进行分队.分队要遵循如下 ...

随机推荐

  1. ISR、OSR、AR 是什么?

    ISR:In-Sync Replicas 副本同步队列 OSR:Out-of-Sync Replicas AR:Assigned Replicas 所有副本 ISR是由leader维护,followe ...

  2. SpingMvc中的控制器的注解一般用那个,有没有别的注解可以替代?

    答:一般用@Controller注解,也可以使用@RestController,@RestController注解相当于@ResponseBody + @Controller,表示是表现层,除此之外, ...

  3. C# 如何让new 出来的form显示在最外层?

    /// <summary> /// 显示比对不同点的位置 /// </summary> public void showDiffImage() { //在此处弹出不一样图 Bi ...

  4. Oracle入门基础(八)一一数据处理

    SQL> SQL的类型 SQL> 1.DML(Data Manipulation Language 数据操作语言): select insert update delete SQL> ...

  5. windows编写sh脚本在linux上不能执行

    报错:/bin/sh^M:bad interpreter: 编码没有被识别, vi *.sh Esc 输入 :set fileformat 查看文件格式(显示  fileformat=dos) Esc ...

  6. python学习笔记(六)——程序调试

    在我们平时编写程序时,常常会遇到各种错误,俗称BUG.而我们程序猿的工作常常需要对程序进行调试,也就是所谓的debug. 程序调试是将编制的程序投入实际运行前,用手工或编译程序等方法进行测试,修正语法 ...

  7. 使用 Vuex + Vue.js 构建单页应用

    鉴于该篇文章阅读量大,回复的同学也挺多的,特地抽空写了一篇 vue2.0 下的 vuex 使用方法,传送门:使用 Vuex + Vue.js 构建单页应用[新篇] ------------------ ...

  8. SDT v0.0.1 上线

    自己的第一个开源组件,断断续续写了有一段时间,感觉可以发布 v0.0.1.SDT 是 SVG Drag Tree 的缩写,一个可以通过拖放 SVG 图标,来生成拥有树形结构的视图与相应数据的前端组件. ...

  9. DRF 视图组件

    目录 DRF 视图组件 视图组件大纲 两个视图基本类 五个扩展类 九个子类视图 视图集 常用视图集父类 魔法类 一览表 DRF中视图的"七十二变" 第一层:基于APIview的五个 ...

  10. 项目需求与分析--NABCD模型

    合作项目特点NABCD分析结果: 特点:便捷 N(Need 需求):在大学期间内,我们通常会有许多不用的课本或书籍或者其他东西,堆积起来又没有地方放,想卖出去就要建一个群,十分麻烦,开发该软件用户可直 ...