并查集的实现(C++)

之前我已经写过一期的并查集的内容,这里主要是实现并查集的整体结构:

#pragma once
//并查集:class UnionFindSet//父母表示法;
{
public://构造函数:UnionFindSet(size_t size=0):_ufs(size,-1){}//合并元素;bool Union(int x, int y){//找到两组元素的rootint root1 = FindRoot(x);int root2 = FindRoot(y);//检查://1.如果两组的root相同,返回false//2.如果两组的root不同,合并,返回trueif (root1 == root2){return false;}else{_ufs[root1] += _ufs[root2];_ufs[root2] = root1;//这里也可以通过压缩路径的方式,简化return true;}}bool UnionSize(int x, int y){int root1 = FindRoot(x);int root2 = FindRoot(y);if (x == y){return false;}else{//按照size合并,数量少的的合并数量多的int size1 = SizeRoot(root1);int size2 = SizeRoot(root2);if (size1 < size2){swap(root1, root2);}_ufs[root1] += _ufs[root2];_ufs[root2] = root1;		return true;}}//查找一个合并集合的root://非递归写法:int FindRoot(int x){//查找root(<0)while (_ufs[x] > 0){x = _ufs[x];}return _ufs[x];}//递归写法:/*int FindRoot(int x){if (x == _ufs[x])return x;elsereturn FindRoot(_ufs[x]);}*///树的个数:size_t Count()const{size_t count = 0;for (auto e : _ufs){count += (e < 0 ? 1 : 0);}return count;//return x == fa[x] ? x : (fa[x] == findset2(fa[x]));//简写}//路径压缩://递归版;int Path_compression(int x){if (x == _ufs[x])return x;_ufs[x] = Path_compression(_ufs[x]);return _ufs[x];}//非递归版;/*int Path_compression(int x){int root = FindRoot(root);while(_ufs[x] != root){int y = _ufs[x];_ufs[x] = root;x = y;}return root;}*///一个树的元素个数:int SizeRoot(int x){int root = FindRoot(x);return abs(_ufs[root]);}
private:vector<int> _ufs;
};

最后,祝福大家学习进步!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/16307.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【云原生】Kubernetes基础命令合集

目录 引言 一、命令概述 &#xff08;一&#xff09;命令分类 &#xff08;二&#xff09;基本语法 二、查看基本信息 &#xff08;一&#xff09;环境指令 1.查看版本信息 2.查看资源对象简写 3.添加补全信息 4.查看日志 5.查看集群信息 &#xff08;二&#xff0…

数据结构(三)

数据结构&#xff08;三&#xff09; 图状关系顺序存储链式存储十字链表法多重链表法 图的遍历佛洛依德算法迪杰斯特拉算法洪水算法 图状关系 按有无方向分&#xff1a;有向图、无向图 按是否有权值&#xff1a;带权图、不带权图 顺序存储 链式存储 十字链表法 多重链表法 图…

【笔记】软件架构师要点记录(2)

【笔记】软件架构师要点记录 20240523案例一案例二案例三案例四案例五案例六案例七案例十 20240523 基于前10个架构案例场景&#xff0c;对用到的专业术语进行整理&#xff0c;方便后续查看。 案例一 MVC架构风格组件交互方式 MVC是一种用来构建用户界面时采用的架构设计风格…

springboot整合chatgpt,并且让其可以记录上下文

整合很简单&#xff0c;不过需要几个小条件 1.必须要有openai官方的key 2.国内需要有代理服务器或者国外的服务器把项目部署出去也没问题 我没有使用spring的springAI&#xff0c;听说很方便&#xff0c;日后有机会去体验体验&#xff0c;我今天用了两种方式整合了gpt 1.Ch…

攻防世界[GoodRe]

攻防世界[GoodRe] 学到知识&#xff1a; 逆向的精髓&#xff1a;三分懂&#xff0c;七分蒙。TEA 算法快速识别&#xff08;蒙&#xff09;&#xff1a; 数据处理的形式&#xff1a;进入加密时的数据和加密结束后的数据&#xff0c;处理时数据的分组等等&#xff0c;都能用来…

使用libtorch加载YOLOv8生成的torchscript文件进行目标检测

在网上下载了60多幅包含西瓜和冬瓜的图像组成melon数据集&#xff0c;使用 LabelMe 工具进行标注&#xff0c;然后使用 labelme2yolov8 脚本将json文件转换成YOLOv8支持的.txt文件&#xff0c;并自动生成YOLOv8支持的目录结构&#xff0c;包括melon.yaml文件&#xff0c;其内容…

VMware虚拟机如何与主机共享文件夹

本机:WIN10 VMware虚拟机:WIN7 因为每次配置都爱忘记操作,目标是为了在WIN7虚拟机中可以访问本机文件 首先本机操作 新建一个共享文件夹,不带中文目录(最好不要) 点击共享 选择everyone,记得权限"读取和写入" 然后到虚拟机里面 添加一个网络位置 点击浏览,选择网…

第一节:Redis的数据类型和基本操作

最近整理了关于Redis的一些文档&#xff0c;分享给大家&#xff0c;后续会持续更新...... Redis的数据类型 字符串String String&#xff1a;字符串&#xff0c;可以存储String、Integer、Float型的数据&#xff0c;甚至是二进制数据&#xff0c;一个字符串最大容量是512M 列表…

IS-IS DIS

原理概述 OSPF 协议支持4种网络类型&#xff0c; IS-IS 协议只支持两种网络类型&#xff0c;即广播网络和点到点网络。与 OSPF 协议相同&#xff0c; IS-IS 协议在广播网络中会将网络视为一个伪节点( Pseudonode &#xff0c;简称 PSN )&#xff0c;并选举出一台 DIS ( Designa…

ISCC2024个人挑战赛WP-WEB

&#xff08;非官方解&#xff0c;以下内容均互联网收集的信息和个人思路&#xff0c;仅供学习参考&#xff09; 还没想好名字的塔防游戏 GET /world.js HTTP/1.1 Host: 101.200.138.180:17345 Accept: text/html,application/xhtmlxml,application/xml;q0.9,image/avif,i…

springcloud多个服务共用同一个nacos配置

spring:profiles:active: devcloud:nacos:config:server-addr: 172.168.1.xx:8848enabled: truefile-extension: yamlnamespace: public#按需引入nacos中的配置#shared-configs: database.yamlextension-configs:# 数据源配置- data-id: database.yamlgroup: DEFAULT_GROUP# re…

【poll函数ppoll函数与epoll函数的区别】

poll函数ppoll函数与epoll函数的区别 pollppollepoll总结 poll poll 是一个比较古老的系统调用&#xff0c;它提供了最基本的多路复用功能。poll 函数的原型如下&#xff1a; int poll(struct pollfd *fds, nfds_t nfds, int timeout);poll 接受一个 pollfd 结构体数组&#…

MySQL查询数据库锁表的SQL语句

在数据库管理和开发过程中&#xff0c;锁&#xff08;Locks&#xff09;是一个重要的概念。锁的存在保证了多个事务能够安全地并发执行&#xff0c;防止数据的不一致。然而&#xff0c;当出现锁等待或死锁问题时&#xff0c;会导致系统性能下降或事务失败。为了有效地解决这些问…

系统思考—问题分析与持续改进

刚刚为一家500强企业完成了《系统思考—问题分析与持续改进》的课程。学员们开始意识到&#xff0c;不能仅仅停留在冰山上层事件去解决问题&#xff0c;而是要深入观察隐藏在背后的趋势变化。学会如何识别系统中的深层次原因&#xff0c;并从全局视角来制定更加有效的改进策略。…

电子电器架构 - 车载网管功能简介

电子电器架构 - 车载网管功能简介 我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证明自己,…

Windows下安装配置深度学习环境

Windows下安装配置深度学习环境 1. 准备工作 1.1 环境准备 操作系统&#xff1a;win10 22H2 GPU&#xff1a;Nvidia GeForce RTX 3060 12G 1.2 安装Nvidia驱动、cuda、cuDNN 下载驱动需要注册并登录英伟达账号。我这里将下面用到的安装包放到了百度网盘&#xff0c;可以关注微信…

DFA 算法

为什么要学习这个算法 前一段时间遇到了瓶颈&#xff0c;因为词库太多了导致会有一些速度过慢&#xff0c;而且一个正则表达式已经放不下了&#xff0c;需要进行拆分正则才可以。 正好我以前看过有关 dfa 的介绍&#xff0c;但是并没有深入的进行研究&#xff0c;所以就趁着周…

词条唤夜兽唤夜兽的养殖与护理 幻兽帕鲁 唤夜兽怎么获取 唤夜兽去哪里抓 crossover玩Steam游戏

唤夜兽在地图上没有出现&#xff0c;是唤冬兽和雷冥鸟共同培育出来的帕鲁。 ------------------------- 介绍&#xff1a; 帕洛斯群岛之守护神&#xff0c;拥呼唤黑夜之力。 其会于灾厄席捲大地之际腾空而起&#xff0c;唤来无尽暗夜&#xff0c;试图封印灾厄。 ---------…

【路径规划】基于遗传算法求解带时间窗容量限制的单配送中心多骑手外卖配送路径规划问题附Matlab代码

研究背景: 随着外卖业务的快速发展,如何合理安排多骑手的配送路径,减少配送时间和成本,成为外卖平台需要解决的重要问题。在实际操作中,骑手需要在一定的时间窗内完成配送,并且配送中心的配送能力也有限,因此需要考虑时间窗和容量限制的多骑手外卖配送路径规划问题。 …

SpringBoot日常:@Scheduled开关控制

场景问题&#xff1a; 日常比较小的项目常常使用springboot中的scheduled注解来完成定时任务。本地和线上dev环境用的是同一套数据源&#xff0c;我们希望所有的定时任务都由线上的去执行&#xff0c;本地不执行&#xff0c;避免数据混乱。那r如何通过配置文件的方式来决定这个…