并查集 左手的ㄟ右手 2022-02-05 00:23 240阅读 0赞 > 并查集是一种树形的数据结构,用于集合的合并。 **与C++STL相比的优势:** 1. 可以同时维护多个集合 2. 快速的合并两个集合 \*\*现实: 用数组实现。father\[1000\];\*\* **1. 初始化:** for(int i=1;i<=n;++i) father\[i\]=i; //默认存在n个根,即n个集合。 **2. 查找一个元素所在的集合(即查找根)** int get(int a){ if(father[a]==a) return a; else return get(father[a]); } *这里解释下,数组的下标代表数组的权值,而数组中的值指的是数组所在的父节点。* **3.合并两个集合。** void merge(int x,int y){//合并 x=get(x); y=get(y); if(x!=y)//先查找两个集合的根,如果根相同,则不合并 father[x]=y;//将集合x的根直接指向集合y的根 } **经典例题**: 在社交的过程中,通过朋友,也能认识新的朋友。在某个朋友关系图中,假定 A 和 B 是朋友,B 和 C 是朋友,那么 A 和 C 也会成为朋友。即,我们规定朋友的朋友也是朋友。 现在,已知若干对朋友关系,询问某两个人是不是朋友。 请编写一个程序来解决这个问题吧。 输入格式 第一行:三个整数 n,m,p(n≤5000,m≤5000,p≤5000), 分别表示有 n 个人,m 个朋友关系,询问 p 对朋友关系。 接下来 m 行:每行两个数 Ai,Bi1≤Ai,Bi≤N,表示 A i和 Bi具有朋友关系。接下来 p行:每行两个数,询问两人是否为朋友。 输出格式 输出共 p 行,每行一个Yes或No。表示第 i个询问的答案为是否朋友。 样例输入 6 5 3 1 2 1 5 3 4 5 2 1 3 1 4 2 3 5 6 样例输出 Yes Yes No #include<iostream> using namespace std; int father[5001]; int get(int a){ if(father[a]==a) return a; else return get(father[a]); } void merge(int x,int y){//合并 x=get(x); y=get(y); if(x!=y) father[x]=y; } int main(){ int n,m,p; cin>>n>>m>>p; for(int i=1;i<=n;++i) father[i]=i; for(int i=1;i<=m;++i){ int x,y; cin>>x>>y; if(get(x)==get(y)) continue; merge(x,y); } for(int i=1;i<=p;++i){ int x,y; cin>>x>>y; if(get(x)==get(y)) cout<<"Yes"<<endl; else cout<<"No"<<endl; } }
相关 并查集 Ⅱ \[poj 1611\] ([http://poj.org/problem?id=1611][http_poj.org_problem_id_1611]) 题目描述: T 古城微笑少年丶/ 2022年08月03日 14:35/ 0 赞/ 253 阅读
相关 并查集 并查集JAVA版框架 并查集是一种用来管理元素分组情况的数据结构。 并查集可以高效地进行如下操作: \--查询元素a和元素b是否属于同一组 落日映苍穹つ/ 2022年06月16日 12:44/ 0 赞/ 288 阅读
相关 并查集 这个文章是几年前水acm的时候转的, 当时也不知道作者是谁, 要是有人知道的话说一下吧 并查集是我暑假从高手那里学到的一招,觉得真是太精妙的设计了。以前我无法解决的 港控/mmm°/ 2022年06月13日 14:13/ 0 赞/ 277 阅读
相关 并查集 > 题目 > 某学校近期要组织全校同学出去参加某项活动,由于人数众多,学校决定让同学们自行组队,以小组为单位进行活动。假设学校一共n个同学,每个同学有一个唯一的数字作为标签 Myth丶恋晨/ 2022年06月08日 09:24/ 0 赞/ 287 阅读
相关 并查集 森林: 森林是由若干棵互不相交的树组成,两棵树分别独立,没有交集 ![20181112082744488.png][] 并查集: 并查集的结构和森林十分相似,是 Love The Way You Lie/ 2022年04月17日 02:27/ 0 赞/ 345 阅读
相关 并查集 来看一个实例,[杭电1232畅通工程][1232] 首先在地图上给你若干个城镇,这些城镇都可以看作点,然后告诉你哪些对城镇之间是有道路直接相连的。最后要解决的是整幅图的连通性 我就是我/ 2022年03月29日 10:58/ 0 赞/ 339 阅读
相关 并查集 并查集 并查集是对树的一种操作,旨在找到某个节点的公共祖先(最老公共祖先)。我们先讲一下并。 并 并就是讲两个节点合并到一个集合里面(这个集合必须是树),每个节点 谁践踏了优雅/ 2021年12月15日 11:33/ 0 赞/ 373 阅读
相关 并查集 例题: ![输入样例][20190805122001677.png] 输入样例,第一行为一个整数n,代表有n台电脑,编号1-n;接下来进行一系列操作,当输入‘c’时,判 Dear 丶/ 2021年11月11日 08:04/ 0 赞/ 368 阅读
相关 并查集 一、算法解释 用于解决一些有N个元素的集合应用问题。 1、将每个元素初始化为自身单独成为一个集合。用p\[i\]的值表示该元素所在集合。 ![这里写图片描述][S 桃扇骨/ 2021年09月14日 02:56/ 0 赞/ 447 阅读
相关 并查集 并查集的作用就是快速判断两个元素是否在同一个集合中,快速将两个集合合并 基本模板 include <iostream> include <a 比眉伴天荒/ 2021年06月22日 15:37/ 0 赞/ 538 阅读
还没有评论,来说两句吧...