C++实现并查集实例

并查集这个很有意思,并查集是一种树型的数据结构,用于处理一些不相交集合(Disjoint Sets)的合并及查询问题。昨天看书看到了,然后用C++简单实现了下。在Dijkstra算法中,用来判断两个顶点是否在同一个集合里。

里面定义了两个类,都是并查集,一个是QuickFind,查找很快,一个是QuickUnion,合并较快。写了一些注释,有一些优化的提示.看代码吧,有什么问题指出来吧。

QuickFind的实现

#include “QuickFind.h”

QuickFind::QuickFind(int N)
{
size=N;
id=new int[N];
for(int i=0;i<N;i++)
{
id[i]=i;
}
}

bool QuickFind::Find(int p,int q)
{
return id[p]==id[q];
}

void QuickFind::Unite(int p,int q)
{
int pid=id[p];
for(int i=0;i<size;i++)
if(id[i]==pid)
id[i]=id[q];

}
QuickFind::~QuickFind(void)
{
delete []id;
}
QuickUnion的实现

#include “QuickUnion.h”

QuickUnion::QuickUnion(int N)
{
size=N;
id=new int[N];
for(int i=0;i<N;i++)
{
id[i]=i;
}
}
int QuickUnion::root(int i)
{
while (i!=id[i])
{
//id[i]=id[id[i]]; 若添加这句话则为压缩路径
i=id[i];
}
return i;
}
bool QuickUnion::Find(int p,int q)
{
return root(p)==root(q);
}

void QuickUnion::Unite(int p,int q)
{
//将p的根挂在q的根上,
//这样会导此数变高,若需要优化,需要设置另一个
//数组sz[],sz[i]表示所以根为i的节点的数目,然后将
//小树靠在大树上

/*
int i=root(p);
int j=root(q);
if(sz[i]&lt;sz[j])
{
    id[i]=j;sz[j]+=sz[i];
}
else
{
    id[j]=i;sz[i]+=sz[j];
}*/
int rootp=root(p);
int rootq=root(q);
id[rootp]=rootq;

}
QuickUnion::~QuickUnion(void)
{
delete []id;
}

时间: 2024-08-02 14:22:32

C++实现并查集实例的相关文章

C++并查集亲戚(Relations)算法实例_C 语言

本文实例讲述了C++并查集亲戚(Relations)算法.分享给大家供大家参考.具体分析如下: 题目: 亲戚(Relations) 或许你并不知道,你的某个朋友是你的亲戚.他可能是你的曾祖父的外公的女婿的外甥的表姐的孙子.如果能得到完整的家谱,判断两个人是否亲戚应该是可行的,但如果两个人的最近公共祖先与他们相隔好几代,使得家谱十分庞大,那么检验亲戚关系实非人力所能及.在这种情况下,最好的帮手就是计算机. 为了将问题简化,你将得到一些亲戚关系的信息,如同Marry和Tom是亲戚,Tom和B en是

数据结构 之 并查集(Disjoint Set)

一.并查集的概念:     首先,为了引出并查集,先介绍几个概念:     1.等价关系(Equivalent Relation)     自反性.对称性.传递性.     如果a和b存在等价关系,记为a~b.     2.等价类:     一个元素a(a属于S)的等价类是S的一个子集,它包含所有与a有关系的元素.注意,等价类形成对S的一个划分:S的每一个成员恰好互斥地出现在一个等价类中.为了确定是否a~b,我们仅需验证a和b是否属于同一个等价类即可.     3.并查集:     即为等价类,

mybatis实现对数据的增删查改实例详解_java

前期准备 新建java工程或java wweb工程,需要导入以下的包, 基本工作已经完成,接下来开始进入正题. 新建实体类 新建与数据库表对应的实体类 package com.edu.hpu.domain; /** * @author Administrator *user表所对应的实体类 */ public class User { //实体类的属性和表的字段名称一一对应 private int id; private String name; private int age; //对属性进行

图的生成树(森林)(克鲁斯卡尔Kruskal算法和普里姆Prim算法)、以及并查集的使用

图的连通性问题:无向图的连通分量和生成树,所有顶点均由边连接在一起,但不存在回路的图. 设图 G=(V, E) 是个连通图,当从图任一顶点出发遍历图G 时,将边集 E(G) 分成两个集合 T(G) 和 B(G).其中 T(G)是遍历图时所经过的边的集合,B(G) 是遍历图时未经过的边的集合.显然,G1(V, T) 是图 G 的极小连通子图,即子图G1 是连通图 G 的生成树. 深度优先生成森林   右边的是深度优先生成森林: 连通图的生成树不一定是唯一的,不同的遍历图的方法得到不同的生成树;从不

并查集(Disjoint Set)

在一些有N个元素的集合应用问题中,我们通常是在开始时让每个元素构成一个单元素的集合,然后按一定顺序将属于同一组的元素所在的集合合并,其间要反复查找一个元素在哪个集合中.这一类问题其特点是看似并不复杂,但数据量极大,若用正常的数据结构来描述的话,往往在空间上过大,计算机无法承受:即使在空间上勉强通过,运行的时间复杂度也极高,根本就不可能在规定的运行时间(1-3秒)内计算出试题需要的结果,只能用并查集来描述. 定义 并查集(Disjoint Set),即"不相交集合",是一种树型的数据结构

HDU 3038 How Many Answers Are Wrong? :带权并查集

链接: http://acm.hdu.edu.cn/showproblem.php?pid=3038 题目: Problem Description TT and FF are ... friends. Uh... very very good friends -________-b FF is a bad boy, he is always wooing TT to play the following game with him. This is a very humdrum game. T

poj 1456 Supermarket:贪心, 并查集

链接: http://poj.org/problem?id=1456 题目: Description A supermarket has a set Prod of products on sale. It earns a profit px for each product x∈Prod sold by a deadline dx that is measured as an integral number of time units starting from the moment the

HDU 2818 Building Block, poj 1988 Cube Stacking:带权并查集

链接: HDU: http://acm.hdu.edu.cn/showproblem.php?pid=2818 POJ:  http://poj.org/problem?id=1988 题目: Problem Description John are playing with blocks. There are N blocks (1 <= N <= 30000) numbered 1...N.Initially, there are N piles, and each pile contai

并查集UFSet类

/* Name: 并查集UFSet类 Copyright: 始发于goal00001111的专栏:允许自由转载,但必须注明作者和出处 Author: goal00001111 Date: 23-12-08 15:21 Description: 实现了普通的查找和合并的算法,也实现了压缩路径和按大小求并高效 算法,并对两者进行了测试比较. 有关算法的分析讨论详见拙作<一种简单而有趣的数据结构--并查集>: http://blog.csdn.net/goal00001111/archive/200