数据结构|树形结构|并查集

数据结构|并查集

并查集

心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。
在这里插入图片描述
有趣的并查集剧情演绎:【算法与数据结构】—— 并查集

并查集
并查集是一种关于管理元素所属集合的数据结构,实现为一个森林,其中每棵树表示一个集合,树中的节点表示对应集合中的元素。
一般地,我们只关心树的根节点树的大小。注意,并查集的最终修改与查询都是根节点,而不是父节点(fa),父节点只是用来实现并查集的过程。因此,查询某个点属于哪个集合以及集合的大小,都是在根节点上进行操作,也就是find(x),但不是fa[x]。

并查集

补充
如果题目中没有给权值,把模板中size部分删除即可

初始化

int fa[N],sz[N];//父节点father和大小sizefor(int i=1;i<=n;i++){fa[i] = i;sz[i] = 1;//sz表示带权并查集,初始可为1可不为1,视具体情况而定}

查询(路径压缩)

int find(int x){//之后再次查询时,时间复杂度为O(1)return fa[x] == x?x:fa[x]=find(fa[x]);
}

按秩合并

void merge(int x,int y){x = find(x),y=find(y);if(x!=y){if(sz[x]>sz[y]) swap(x,y);fa[x]=y;sz[y]+=sz[x];}
}
//实际上按秩合并不是必须的,实际上按秩合并完全可由路径压缩替代。因为路径压缩已经将时间复杂度降到了O(1)。

二维并查集

//只需一个hash映射,将二维映射到一维即可
for(int i=0;i<n;i++){for(int j=0;j<n;j++){fa[i*n+j] = i*n+j;sz[i*n+j] = 1;}
}

删除节点

int cnt=n-1;for(int i=0;i<n;i++) real[i]=i;void delete(int x){real[x]=++cnt;fa[real[x]]=real[x];x=find(x);sz[x]-=1;
}

例题
蓝桥杯2017国赛真题-合根植物

心有猛虎,细嗅蔷薇。再见了朋友~

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

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

相关文章

JavaScript —— APIs(三)

一、事件流 &#xff08;一&#xff09;定义 &#xff08;二&#xff09;事件捕获 事件捕获&#xff0c;对话框从大到小弹出&#xff0c;先弹出爷爷&#xff0c;最后弹出儿子 &#xff08;三&#xff09;事件冒泡 冒泡事件&#xff0c;对话框从小到大弹出&#xff0c;先弹出…

详解QString与QByteArray使用对比

QString与QByteArray是Qt库中两种不同的字符串/字节序列容器&#xff0c;各自服务于特定的应用场景。本篇文章将详细解析它们的异同&#xff0c;帮助您在实际编程中准确选择和有效地使用这两种类型。 参考 QString类的使用 相同之处 构造与初始化&#xff1a; 两者都支持直接使…

Apache Answer 开源问答社区安装体验

Answer 是由 SegmentFault 思否团队打造的一款问答平台软件,后端使用 Go 语言编写,于2022年10月24日(程序员节)正式开源。你可以免费使用 Answer 高效地搭建一个问答社区,并用于产品技术问答、客户支持、用户交流等场景。 2023年10月9日,Answer 顺利通过投票,以全票通过…

Binlog、Redo 和 Undo 的概念与区别

目录 Binlog&#xff08;Binary Log&#xff09; Redo Log&#xff08;重做日志&#xff09; Undo Log&#xff08;回滚日志&#xff09; Binlog 与 Redo Log 和 Undo Log 的区别 Binlog&#xff08;Binary Log&#xff09; Binlog&#xff0c;即二进制日志&#xff0c;是M…

华为sr-mpls policy配置案例

SR&#xff0d;MPLS POLICY在ensp上面做不了&#xff0c;这是官方上的配置

编译Milkv-duo固件

Milk-V Duo 是一款基于 CV1800B 芯片的超紧凑型嵌入式开发平台。它可以运行Linux和RTOS&#xff0c;为专业人士、工业ODM、AIoT爱好者、DIY爱好者和创作者提供可靠、低成本、高性能的平台。 硬件 CPU&#xff1a;CVITEK CV1800B (C9061Ghz C906700MHz)双 RV64 内核&#xff…

node+vue3的websocket前后端消息推送

nodevue3的websocket前后端消息推送 前期写web项目时&#xff0c;前端获取数据的方式一般是向后端发起数据请求&#xff0c;然后后端向前端发送数据&#xff0c;然后对数据进行渲染&#xff0c;这是最常规的一种数据通讯方式&#xff0c;适用于绝大部分前后端分离的项目 实际…

多项式和Bezier曲线拟合

目录 1. 多项式拟合2. Bezier曲线拟合3. 源码地址 1. 多项式拟合 在曲线拟合中&#xff0c;多项式拟合方法的性能受到三个主要因素的影响&#xff1a;采样点个数、多项式阶数和正则项。 采样点个数 N N N&#xff1a;从Figure 1中可以看出较少的采样点个数可能导致过拟合&…

2024统计建模:大数据与人工智能时代的统计研究

文章目录 题目解读你需要具备的知识点课题推荐视频分析 题目解读 主要做的是“大数据”与“人工智能”。 其中“大数据”所涉及的的第一个就是大量的数据&#xff0c;数据从哪里来&#xff1f;拿到数据后&#xff0c;我们需要做基本的数据分析&#xff0c;如何对大量的数据进…

Springboot2.7解决静态资源302问题

application.yml配置&#xff1a; spring: mvc: static-path-pattern: /static/** web: resources: static-locations: classpath:/static/ 配置后&#xff0c;静态资源是生效了。 但在页面上显示有些是200&#xff0c;有些是302&#xff0c;不同的状态&#xff0c; 觉得很…

华为OD机试真题-贪吃的猴子-2024年OD统一考试(C卷D卷)

题目描述: 一只贪吃的猴子,来到一个果园,发现许多串香蕉排成一行,每串香蕉上有若干根香蕉。每串香蕉的根数由数组numbers给出。猴子获取香蕉,每次都只能从行的开头或者末尾获取,并且只能获取N次,求猴子最多能获取多少根香蕉。 输入描述: 第一行为数组numbers的长度 第二…

Flink cdc如何只进行增量同步,不同步历史数据(只读取binlog)

环境 flink: 1.15.3 flink-connector-mysql-cdc: 2.4.0 场景&#xff1a; mysql cdc到starrocks&#xff0c; 目前线上环境以及有老的任务在同步&#xff0c;现在升级了任务&#xff08;旧checkpoints无法使用&#xff09;旧表里面数据特别大&#xff0c;不方便重新同步 方…

Window系统mysql数据库定时备份脚本

将下面的内容复制到bat文件里&#xff0c;然后将5个变量进行修改&#xff1a; mysqldumpPath 你本地mysql路径 dbName 需要备份的数据库 dbUser 数据库用户名 dbPwd 数据库密码 outpurDir 备份文件输出路径 echo 取日期、时间变量值 set yy%date:~0,4% set mm%date:~5,2% set …

Java8 Optional类使用总结

前言 相信不少小伙伴已经被java的NPE(NullPointer Exception)所谓的空指针异常搞的头昏脑涨, 有大佬说过“防止 NPE&#xff0c;是程序员的基本修养。”但是修养归修养&#xff0c;也是我们程序员最头疼的问题之一&#xff0c;那么我们今天就要尽可能的利用Java8的新特性 Opti…

聚道云一键打通金蝶宁波银行,财务效率暴涨10倍!

客户介绍&#xff1a; 某农资有限公司是一家集农资贸易、仓储物流、农机服务为一体的大型企业。随着业务规模的不断扩大&#xff0c;传统的手动财务操作模式已难以满足其需求。公司急需寻找一种方法&#xff0c;将金蝶财务软件与宁波银行对接&#xff0c;实现资金流转自动化和…

深入React Hooks:从源码剖析到高级实践(Vue 同学必看指南)

深入React Hooks&#xff1a;从源码剖析到高级实践 React Hooks作为一项重大革新&#xff0c;彻底改变了React应用的状态管理与生命周期逻辑&#xff0c;极大地提升了代码的可读性、可复用性和简洁性。本文将带领熟悉Vue技术栈的读者&#xff0c;浅析React Hooks的内在机制&am…

python使用selenium如何获取一个div下所有的文本

在Python中使用Selenium获取一个<div>元素下所有的文本可以通过多种方式实现。一种简单的方法是首先获取<div>元素&#xff0c;然后使用text属性来获取其内部的文本内容。但这种方法可能不会获取到<div>元素内嵌套的其他标签&#xff08;如<span>、<…

045、seq2seq

之——序列生成 杂谈 基于RNN实现&#xff0c;通过RNN生成器不断获取输入&#xff0c;更新隐藏状态&#xff0c;将最后生成的隐藏状态传递给解码器&#xff0c;然后自循环迭代直到输出停止。 正文 1.训练 训练时候解码器使用目标句子不断作为输入&#xff0c;就算解码错了输入…

C# 通过阿里云 API 实现企业工商数据查询

目录 应用场景 关于阿里云企业工商数据查询API 开发运行环境 类设计 类属性 类方法 实现代码 创建 Company 类 调用举例 小结 应用场景 在企业会员后台注册系统中&#xff0c;为验证企业名称是否输入完整且是有效存在的&#xff0c;则可以通过云API服务的方式进行验…

如何解决升级IntelliJ IDEA 2024后 打开项目就自动闪退关闭问题的终极指南

title: “&#x1f42f; 解决升级IntelliJ IDEA 2024后项目自动关闭的终极指南” date: 2024-04-23 author: 猫头虎 profile: CSDN 文章目录 title: "&#x1f42f; 解决升级IntelliJ IDEA 2024后项目自动关闭的终极指南" date: 2024-04-23 author: 猫头虎 profile: …