当前位置: 首页 > news >正文

「图::连通」详解并查集并实现对应的功能 / 手撕数据结构(C++)

目录

概述

成员变量

创建销毁

根节点访问

路径压缩

启发式合并

复杂度

Code


概述

并查集,故名思议,能合并、能查询的集合,在图的连通性问题和许多算法优化上着广泛的使用。

这是一个什么数据结构呢?

一般来讲,并查集是由一系列集合组成的集合群。

其中,每个集合都有一个根节点,它的父亲仍是它自己,集合内其余的节点的父亲or祖宗均是这个节点,这样,一个根节点就领导了一个集合。而并查集支持这样的多个集合的访问以及合并操作。

每个集合都是一个树形结构,你可以认为并查集是一片森林。

听起来挺复杂度,但是其实很好实现。

成员变量

static constexpr int N = 1e5 + 5;一个无关紧要的常量,限制最大值。

int pre[N];父节点指针数组,pre[i]=j表示i的父亲是j,即二者处于同一集合。

int size[N];集合大小数组,只用每个集合的根节点上的size是有意义的,若i为根节点size[i]=x表示i所在的集合大小为x。

struct union_find_set {static constexpr int N = 1e5 + 5;int pre[N],size[N];...
};

创建销毁

在一开始,每个节点都单独成为一个集合,每个集合大小为1。

union_find_set(int n = N) {for (int i = 0; i < n; i++) {pre[i] = i;size[i] = 1;}
}

根节点访问

给定一个节点x,我们想访问他的根节点

这一步可以递归实现:我们知道只有根节点的pre指向自己,所以如果pre[x]==x,我们就找到了根节点,否则沿着pre指针爬,传入下一级root。

int root(int x) {return pre[x] == x ? x : root(pre[x]);
}

路径压缩

沿着pre指针爬树的过程的时间复杂度是线性级别的,但是我们可以使用路径压缩

当我们依次跳出递归时,额外将这一级x的pre指针更新为找到的根节点,这样,一棵树就由多层被压缩成了两层(根节点与叶子节点)。

int root(int x) {return pre[x] = (pre[x] == x ? x : root(pre[x]));
}

启发式合并

想合并两个集合,我们可以采用启发式合并,即按规模合并。

路径压缩并不是实时的,所以一般一个集合仍是多层的。在这种情况下,为了保持查询根节点的高效性,我们应该将小集合接在大集合之下(小集合中节点少,向上访问的总代价小,如果反过来,那么大集合中的大量节点想向上访问会极其不利)。

给出两个节点,将其所在的集合合并,我们先找出root,如果两个节点确实属于不同集合,我们将小集合接在大集合之下,这样就能保持根节点查询的效率。最后根节点的size。

void unite(int x, int y) {x = root(x), y = root(y);if (x == y)return;if (size[y] < size[x])std::swap(x, y);pre[x] = y;size[y] += size[x];
}

复杂度

时间复杂度:O(n) 使用路径压缩:O(1)~O(logn)

空间复杂度:O(n) 

Code

#include <algorithm>
#ifndef UNION_FIND_SET
#define UNION_FIND_SET
struct union_find_set {static constexpr int N = 1e5 + 5;int pre[N],size[N];union_find_set(int n) {for (int i = 0; i < n; i++) {pre[i] = i;size[i] = 1;}}int root(int x) {return pre[x] = (pre[x] == x ? x : root(pre[x]));}int get_size(int x) {return size[root(x)];}void unite(int x, int y) {x = root(x), y = root(y);if (x == y)return;if (size[y] < size[x])std::swap(x, y);pre[x] = y;size[y] += size[x];}
};
#endif

相关文章:

「图::连通」详解并查集并实现对应的功能 / 手撕数据结构(C++)

目录 概述 成员变量 创建销毁 根节点访问 路径压缩 启发式合并 复杂度 Code 概述 并查集&#xff0c;故名思议&#xff0c;能合并、能查询的集合,在图的连通性问题和许多算法优化上着广泛的使用。 这是一个什么数据结构呢&#xff1f; 一般来讲&#xff0c;并查集是…...

基于PSO粒子群优化的CNN-GRU-SAM网络时间序列回归预测算法matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 (完整程序运行后无水印) PSO优化过程&#xff1a; PSO优化前后&#xff0c;模型训练对比&#xff1a; 数据预测对比&#xff1a; 误差回归对比&a…...

PyTorch 的 DataLoader 类介绍

DataLoader 类 功能与作用 PyTorch 是一个流行的开源机器学习库&#xff0c;它提供了一个名为 DataLoader 的类&#xff0c;用于加载数据集并将其封装成一个可迭代的对象。DataLoader 可以自动地将数据集划分为多个批次&#xff0c;并在训练过程中迭代地返回这些批次。是用于加…...

【设计模式系列】命令模式

目录 一、什么是命令模式 二、命令模式的角色 三、命令模式的典型应用场景 四、命令模式在Runnable中的应用 一、什么是命令模式 命令模式&#xff08;Command Pattern&#xff09;是一种行为设计模式&#xff0c;它将一个请求或简单操作封装为一个对象。这个模式提供了一种…...

uniapp中使用lottie实现JSON动画

uniapp中使用lottie实现JSON动画 不喜欢废话直接开干一、引入相关依赖二、在项目的目录新建目录结构三、操作步骤四、编写自定义组件代码五、组件的使用提一嘴更多lottie-web常用方法添加点击事件 不喜欢废话直接开干 一、引入相关依赖 npm install lottie-web # 如果有问题可…...

AcWing275

题目重述 这道题的核心是利用方格取数模型的思想&#xff0c;将两条路径的传递过程映射为同时出发的两条路径&#xff0c;避免重复格子的经过。题解通过以下步骤解题&#xff1a; 路径映射&#xff1a;从 (n, m) 回到 (1, 1) 的路径&#xff0c;可以转换成 (1, 1) 到 (n, m) …...

Windows系统部署redis自启动服务【亲测可用】

文章目录 引言I redis以本地服务运行(Windows service)使用MSI安装包配置文件,配置端口和密码II redis服务以终端命令启动缺点运行redis-server并指定端口和密码III 知识扩展确认redis-server可用性Installing the Service引言 服务器是Windows系统,所以使用Windows不是re…...

深入了解机器学习 (Descending into ML):线性回归

人们早就知晓&#xff0c;相比凉爽的天气&#xff0c;蟋蟀在较为炎热的天气里鸣叫更为频繁。数十年来&#xff0c;专业和业余昆虫学者已将每分钟的鸣叫声和温度方面的数据编入目录。Ruth 阿姨将她喜爱的蟋蟀数据库作为生日礼物送给您&#xff0c;并邀请您自己利用该数据库训练一…...

每日OJ题_牛客_集合_排序_C++_Java

目录 牛客_集合_排序 题目解析 C代码 Java代码 牛客_集合_排序 集合_牛客题霸_牛客网 (nowcoder.com) 题目解析 笔试题可直接用set排序&#xff0c;面试可询问是否要手写排序函数&#xff0c;如果要手写排序&#xff0c;推荐写快排。 C代码 #include <iostream> …...

鸿蒙网络编程系列27-HTTPS服务端证书的四种校验方式示例

1. 服务端数字证书验证的问题 在鸿蒙客户端对服务端发起HTTPS请求时&#xff0c;如果使用HttpRequest的request发起请求&#xff0c;那么就存在服务端数字证书的验证问题&#xff0c;你只有两个选择&#xff0c;一个是使用系统的CA&#xff0c;一个是使用自己选定的CA&#xf…...

scala继承

Scala中继承的定义为在原有类的基础上定义一个新类&#xff0c;原有类称为父类&#xff0c;新类称为子类。 当子类从父类中继承的方法不能满足需要时&#xff0c;子类需要有自己的行为&#xff0c;怎么办&#xff1f; 此时使用override可以重写父类方法。 class Aniaml(){va…...

【Hive】2-Apache Hive概述、架构、组件、数据模型

Apache Hive概述 什么是Hive Apache Hive是一款建立在Hladoop之上的开源数据仓库系统&#xff0c;可以将存储在Hadoop文件中的结构化、半结构化数据文件映射为一张数据库表&#xff0c;基于表提供了一种类似SQL的查询模型&#xff0c;称为Hive查询语言(HQL)&#xff0c;用于访…...

关于目前面试八股文的一些心得体会

现在是2024年10月&#xff0c;自22年开始&#xff0c;明显感觉到整个计算机行业&#xff0c;越来越卷了。一方面&#xff0c;随着信息的传播&#xff0c;越来越多的新人涌入了这个赛道&#xff0c;另一方面&#xff0c;众所周知的原因&#xff0c;不管大厂还是小厂在经历寒冬之…...

大数据-178 Elasticsearch Query - Java API 索引操作 文档操作

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; 目前已经更新到了&#xff1a; Hadoop&#xff08;已更完&#xff09;HDFS&#xff08;已更完&#xff09;MapReduce&#xff08;已更完&am…...

PHP(一)从入门到放弃

参考文献&#xff1a;https://www.php.net/manual/zh/introduction.php PHP 是什么&#xff1f; PHP&#xff08;“PHP: Hypertext Preprocessor”&#xff0c;超文本预处理器的字母缩写&#xff09;是一种被广泛应用的开放源代码的多用途脚本语言&#xff0c;它可嵌入到 HTML…...

基于深度学习的生物启发的学习系统

基于深度学习的生物启发学习系统&#xff08;Biologically Inspired Learning Systems&#xff09;旨在借鉴生物大脑的结构和学习机制&#xff0c;设计出更高效、更灵活的人工智能系统。这类系统融合了生物神经科学的研究成果&#xff0c;通过模仿大脑中的学习模式、记忆过程和…...

10_实现readonly

在某些时候&#xff0c;我们希望定义一些数据是只读的&#xff0c;不允许被修改&#xff0c;从而实现对数据的保护&#xff0c;即为 readonly 只读本质上也是对数据对象的代理&#xff0c;我们同样可以基于之前实现的 createReactiveObject 函数来实现&#xff0c;可以为此函数…...

简单介绍$listeners

$listeners 它可以获取父组件传递过来的所有自定义函数&#xff0c;如下&#xff1a; // 父组件 <template><div class"a"><Child abab"handleAbab" acac"handleAcac"/></div> </template><script> impor…...

架构设计笔记-20-补充知识

知识产权 我国没有专门针对知识产权制定统一的法律(知识产权法)&#xff0c;而是在民法通则规定的原则下&#xff0c;根据知识产权的不同类型制定了不同的单项法律及法规&#xff0c;如著作权法、商标法、专利法、计算机软件保护条例等&#xff0c;这些法律、法规共同构成了我…...

scrapy 爬虫学习之【中医药材】爬虫

本项目纯学习使用。 1 scrapy 代码 爬取逻辑非常简单&#xff0c;根据url来处理翻页&#xff0c;然后获取到详情页面的链接&#xff0c;再去爬取详情页面的内容即可&#xff0c;最终数据落地到excel中。 经测试&#xff0c;总计获取 11299条中医药材数据。 import pandas as…...

保姆级教程:在Ubuntu 22.04上从源码编译安装Micro XRCE-DDS Agent(附虚拟机环境配置)

从零构建嵌入式通信桥梁&#xff1a;Ubuntu 22.04源码编译Micro XRCE-DDS Agent全指南 当AURIX Tricore这类嵌入式设备需要与复杂系统对话时&#xff0c;XRCE-DDS就像一位专业翻译官。想象一下&#xff0c;你的开发板是个只会说方言的本地向导&#xff0c;而云端服务是个讲标准…...

智能体公司的发展都会变成解决方案型公司

当前AI智能体公司众多&#xff0c;但多数难以持续盈利。主要原因在于AI本质是工具&#xff0c;仅能解放生产力而非解决生产关系&#xff0c;对业务直接收入提升有限&#xff1b;其次&#xff0c;多数团队缺乏行业经验&#xff0c;商业模式局限于传统互联网模式&#xff0c;难以…...

利用快马平台快速搭建stm32f103c8t6最小系统板LED闪烁原型

最近在做一个嵌入式小项目&#xff0c;用到了经典的stm32f103c8t6最小系统板。作为嵌入式开发新手&#xff0c;最头疼的就是搭建开发环境和写各种初始化代码。不过这次尝试用InsCode(快马)平台后&#xff0c;整个过程顺畅多了&#xff0c;分享下我的经验。 项目背景 stm32f103c…...

弃投《Nature Communications》转投它?这些期刊正在让这批科研人弯道超车!

《Science Advances》影响因子分区自引率12.5JCR Q1 / 综合1区 1.6%研究方向&#xff1a;多学科综合、自然科学与工程期刊亮点&#xff1a;AAAS顶刊&#xff0c;年发文约2000篇&#xff0c;国人占比约30%&#xff0c;审稿3-5个月&#xff0c;OA发表&#xff0c;是各学科冲一区顶…...

在Discord上实时展示你的网易云音乐和QQ音乐播放状态

在Discord上实时展示你的网易云音乐和QQ音乐播放状态 【免费下载链接】NetEase-Cloud-Music-DiscordRPC 在Discord上显示网抑云/QQ音乐. Enables Discord Rich Presence For Netease Cloud Music/Tencent QQ Music. 项目地址: https://gitcode.com/gh_mirrors/ne/NetEase-Cl…...

八大网盘直链下载助手:免费获取高速下载链接的完整指南

八大网盘直链下载助手&#xff1a;免费获取高速下载链接的完整指南 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 &#xff0c;支持 百度网盘 / 阿里云盘 / 中国移动云盘 / 天翼…...

【GESP】C++五级练习题 luogu-P1226 【模板】快速幂

GESP C 五级练习题&#xff0c;考查并应用快速幂知识点。题目难度⭐⭐☆☆☆&#xff0c;洛谷难度等级普及−。 luogu-P1226 【模板】快速幂 题目要求 题目题解详见&#xff1a;https://www.coderli.com/gesp-5-luogu-p1226/ https://www.coderli.com/gesp-5-luogu-p1226/ht…...

重塑Obsidian代码块体验:从功能增强到知识管理升级

重塑Obsidian代码块体验&#xff1a;从功能增强到知识管理升级 【免费下载链接】obsidian-better-codeblock Add title, line number to Obsidian code block 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian-better-codeblock 突破笔记局限&#xff1a;代码块美…...

突破限制的AI开发助手:Cursor Free VIP开源工具全攻略

突破限制的AI开发助手&#xff1a;Cursor Free VIP开源工具全攻略 【免费下载链接】cursor-free-vip [Support 0.45]&#xff08;Multi Language 多语言&#xff09;自动注册 Cursor Ai &#xff0c;自动重置机器ID &#xff0c; 免费升级使用Pro 功能: Youve reached your tri…...

Wan2.2-I2V-A14B在Qt桌面程序中的应用:开发本地化视频创作工具

Wan2.2-I2V-A14B在Qt桌面程序中的应用&#xff1a;开发本地化视频创作工具 1. 引言&#xff1a;让AI视频生成触手可及 想象一下&#xff0c;一个普通用户无需学习复杂的命令行&#xff0c;只需拖拽图片、滑动几个调节条&#xff0c;就能轻松将静态图片变成生动的视频。这正是…...