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

算法学习笔记之并查集

简介

问题描述:将编号为1-N的N个对象划分为不相交集合,在每个集合中,选择其中的某个元素代表所在集合。

常见两种操作:

1.合并两个集合

2.查找某元素属于哪个集合

实现方法1

用编号最小的元素标记所在集合;

定义一个数组Set[1...n],其中Set[i]表示元素i所在的集合

效率分析1

查找:O(1)

find(x){return Set[x];}

合并:O(N)

 Merge(a, b){i = min(a, b);j = max(a, b);for(k = 1; k <= N; k++){if(Set[k] == j){Set[k] = i;}}}

实现方法2

效率分析2

查找:最坏为O(N),一般为O(log N)

 find(x){r = x;while(Set[t] != r)r = Set[r];return r;}

合并:O(1)

 merge(a, b){Set[a] = b;}

最坏情况避免

例1

思路:并查集模板,计算集合数量即可

 #include<iostream>using namespace std;​int bin[1002];int findx(int x){int r = x;while(bin[r] != r)r = bin[r];return r;}void merge(int x, int y){int fx, fy;fx = findx(x);fy = findx(y);if(fx != fy)bin[fx] = fy;}int main(){int n, m, x, y, count = -1;while(scanf("%d", &n), n){for(int i = 1; i <= n; i++){bin[i] = i;}for(scanf("%d", &m); m > 0; m--){scanf("%d %d", &x, &y);merge(x, y);}for(int i = 1; i <= n; i++){if(bin[i] == i){count ++;}}printf("%d\n", count);}return 0;}

例2

小希希望任意两个房间有且仅有一条路径可以相通(除非走了回头路)。小希现在把她的设计图给你,让你帮忙判断她的设计图是否符合她的设计思路。

思路:判断迷宫是否有环

最小生成树

Kruskal算法

用于求最小生成树

理论基础:MST性质:对于一个连通图,至少存在一棵最小生成树,包含最短的这条边。

可以采用反证法进行证明

算法步骤:

一、把原始图的N个节点看成N个独立子图;

二、每次选取当前最短的边,若边的两端点属于不同的子图,则加入该边;否则放弃

三、循环操作步骤二,直到有N-1条边;

例3

分析:计算最小生成树

相关文章:

算法学习笔记之并查集

简介 问题描述&#xff1a;将编号为1-N的N个对象划分为不相交集合&#xff0c;在每个集合中&#xff0c;选择其中的某个元素代表所在集合。 常见两种操作&#xff1a; 1.合并两个集合 2.查找某元素属于哪个集合 实现方法1 用编号最小的元素标记所在集合&#xff1b; 定义…...

【开源项目】ShowDoc适合IT团队的在线API文档、技术文档工具

1. 介绍 通过showdoc&#xff0c;可以方便地使用markdown语法来书写出美观的API文档、数据字典文档、技术文档、在线excel文档等等。还可以利用showdoc的自动化能力&#xff0c;从程序注释中自动生成API文档&#xff0c;或者从搭配的RunApi客户端&#xff08;类似postman的api…...

Tomcat添加到Windows系统服务中,服务名称带空格

要将Tomcat添加到Windows系统服务中&#xff0c;可以通过Tomcat安装目录中“\bin\service.bat”来完成&#xff0c;如果目录中没有service.bat&#xff0c;则需要使用其它方法。 打到CMD命令行窗口&#xff0c;通过cd命令跳转到Tomcat安装目录的“\bin\”目录&#xff0c;然后执…...

SQL最佳实践(笔记)

写在前面&#xff1a; 之前baeldung的Java Weekly &#xfeff;Reviews里面推荐了一篇关于SQL优化的文章&#xff0c;正好最近在学习数据库相关知识&#xff0c;记一些学习笔记 原文地址&#xff1a;SQL Best Practices Every Java Engineer Must Know 1. 使用索引 使用索引…...

历史性突破!DeepSeek双模型GitHub热度超OpenAI,展现中国AI力量

在2025年2月7日&#xff0c;中国AI领域传来了一则振奋人心的消息&#xff1a;DeepSeek旗下的两大开源项目在GitHub平台上实现了历史性突破&#xff0c;其Star数成功超越了OpenAI的明星项目。这一成就不仅标志着DeepSeek在技术研发和市场影响力上的重大飞跃&#xff0c;也为中国…...

deepseek+kimi一键生成PPT

1、deepseek生成大纲内容 访问deepseek官方网站&#xff1a;https://www.deepseek.com/ 将你想要编写的PPT内容输入到对话框&#xff0c;点击【蓝色】发送按钮&#xff0c;让deepseek生成内容大纲&#xff0c;并以markdown形式输出。 等待deepseek生成内容完毕后&#xff0c…...

Java学习

一、赋值 赋值表达式&#xff0c;左边一定是变量&#xff0c;右边是变量或者数值&#xff0c;变量与数值都有类型&#xff0c;(数值里整数默认int,小数默认double) 类型由小转大&#xff0c;存储空间变大&#xff0c;数据不会丢失&#xff0c;是安全的&#xff0c;在需要时编译…...

Shell-基本命令与运算符

1.为什么要进行shell编程? 在Linux系统中&#xff0c;虽然有各种各样的图形化接口工具&#xff0c;但是shell仍然是一个非常灵活的 工具。 Shell不仅仅是命令的收集&#xff0c;而且是一门非常棒的编程语言。 您可以通过使用shell使大量的任务自动化&#xff0c; 因此&#…...

JUnit 5 自定义注解:方法级 JSON 参数注入

JUnit 5 自定义注解&#xff1a;方法级 JSON 参数注入 为了实现 在测试方法上使用注解&#xff0c;并通过注解属性指定参数名称和 JSON 字符串&#xff08;转换为 Java 对象&#xff09;&#xff0c;以下是基于 JUnit 5 正确扩展接口的解决方案&#xff1a; 一、实现步骤 1. …...

anolis os 8.9安装jenkins

一、系统版本 # cat /etc/anolis-release Anolis OS release 8.9 二、安装 # dnf install -y epel-release # wget -O /etc/yum.repos.d/jenkins.repo https://pkg.jenkins.io/redhat-stable/jenkins.repo # rpm --import https://pkg.jenkins.io/redhat-stable/jenkins.…...

【CXX】0 Rust与C 互操作利器:CXX库介绍与示例

CXX库是一个非常强大的工具&#xff0c;它使得Rust和C之间的互操作性变得既安全又高效。本专栏将展示如何使用CXX库来桥接Rust和C代码&#xff0c;同时保持两者语言的特性和惯用法。 一、关键概念回顾 类型安全&#xff1a;CXX库通过静态分析类型和函数签名来保护Rust和C的不…...

tensorflow环境中已安装库

1. 深度学习课前准备工作 Anaconda3、TensorFlow和keras安装方法 1 下载Anaconda&#xff1a; Anaconda3-5.2.0-Windows-x86_64.exe 双击安装&#xff0c;选定环境变量 2 开始菜单打开Anaconda Prompt&#xff1a;&#xff08;2、3、4有链接科学上网&#xff09; 创建环境&am…...

构建现代微服务安全体系:Spring Security、JWT 与 Spring Cloud Gateway 实践

构建现代微服务安全体系&#xff1a;Spring Security、JWT 与 Spring Cloud Gateway 实践 本文将基于提供的代码示例&#xff0c;详细介绍如何在一个Java微服务项目中使用Spring Security、JWT和Spring Cloud Gateway来构建一个高效且安全的微服务体系&#xff0c;并整合性能优…...

蓝桥杯(B组)-每日一题(求最大公约数最小公倍数)

题目&#xff1a; 代码展现&#xff1a; #include<iostream> using namespace std; int main() {int m,n,x,y;cin>>m>>n;//输入两个整数int b;bm%n;//取余数xm;//赋值yn;while(b)//当余数不为0的时候{xy;//辗转相除求最小公约数yb;bx%y;}cout<<y<&…...

RocketMQ、RabbitMQ、Kafka 的底层实现、功能异同、应用场景及技术选型分析

1️⃣ 引言 在现代分布式系统架构中&#xff0c;&#x1f4e9;消息队列&#xff08;MQ&#xff09;是不可或缺的组件。它在系统&#x1f517;解耦、&#x1f4c9;流量削峰、⏳异步处理等方面发挥着重要作用。目前&#xff0c;主流的消息队列系统包括 &#x1f680;RocketMQ、&…...

CEF132编译指南 MacOS 篇 - 构建 CEF (六)

1. 引言 经过前面一系列的精心准备&#xff0c;我们已经完成了所有必要的环境配置和源码获取工作。本篇作为 CEF132 编译指南系列的第六篇&#xff0c;将详细介绍如何在 macOS 系统上构建 CEF132。通过配置正确的编译命令和参数&#xff0c;我们将完成 CEF 的构建工作&#xf…...

使用stm32控制esp01s

title: 使用stm32控制esp01s date: 2025年2月9日 18:41:20 tags: 单片机模块使用 categories: stm32 description: 使用stm32控制esp01s连接WiFi查看内容等操作 前言 使用stm32f103控制esp01s是步入物联网的第一步&#xff0c;接下来的文章会详细讲解如何使用stm32控制esp01s…...

返回倒数第N个链表节点

力扣题目&#xff1a;LCR 140. 训练计划 II - 力扣&#xff08;LeetCode&#xff09; 给定一个头节点为 head 的链表用于记录一系列核心肌群训练项目编号&#xff0c;请查找并返回倒数第 cnt 个训练项目编号。 示例 1&#xff1a; 输入&#xff1a;head [2,4,7,8], cnt 1 输…...

一、计算机等级考试——标准评分

&#xff08;1&#xff09;选择题 未做选择题 &#xff08;2&#xff09;基本造作 &#xff08;3&#xff09;上网题 &#xff08;4&#xff09;文字题 &#xff08;5&#xff09;表格题 &#xff08;6&#xff09;演示文稿 二、计算机等级考试——题库 &#xff08;1&#x…...

tweenjs动画

目录 ​编辑 安装 HTML中应用 Threejs中应用 安装 npm install tweenjs/tween.js HTML中应用 <script src"https://cdnjs.cloudflare.com/ajax/libs/tween.js/23.1.3/tween.umd.js"></script><div id"box"></div><style…...

IGBT工作原理

IGBT其实可以看成是BJT和MOS管的融合体&#xff0c;IGBT具有BJT的输入特性和mos管的输出特性。与 BJT 或 MOS管相比&#xff0c;绝缘栅双极型晶体管 IGBT 的优势在于它提供了比标准双极型晶体管更大的功率增益&#xff0c;以及更高的工作电压和更低的 MOS 管输入损耗。 IGBT是绝…...

FlashDecoding

Flash Attention是将Q划分到所有SM block上。每个SM block上的Q&#xff0c;负责和所有K和所有V进行计算&#xff0c;得到对应的结果。期间&#xff0c;SM block彼此之间&#xff0c;不需要通信。 在prefill阶段&#xff0c;seqLength*batchSize*Heads足够多&#xff0c;所以每…...

03:Spring之Web

一&#xff1a;Spring整合web环境 1&#xff1a;web的三大组件 Servlet&#xff1a;核心组件&#xff0c;负责处理请求和生成响应。 Filter&#xff1a;用于请求和响应的预处理和后处理&#xff0c;增强功能。 Listener&#xff1a;用于监听 Web 应用中的事件&#xff0c;实…...

OpenWebUI使用DeepSeek R1满血版,DeepSeek R1 API调用

https://www.dong-blog.fun/post/1935 API调用 登录这里&#xff1a; https://console.volcengine.com/ark/region:arkcn-beijing/endpoint?config%7B%7D 注册后&#xff0c;创建DeepSeek R1 API接入点&#xff1a; 接着Python就可以直接调用了&#xff1a; import os fro…...

DeepSeek模型场景应用:基于腾讯云HAI搭建IDEA开发助手

前言 这段时间国产大模型DeepSeek十分火爆&#xff0c;DeepSeek模型凭借其强大的语言理解和生成能力&#xff0c;为开发场景带来了全新的可能性&#xff0c;DeepSeek模型场景应用也是十分广泛&#xff0c;而基于腾讯云HAI搭建IDEA开发助手&#xff0c;更是将这种潜力发挥到了极…...

HttpServletRequest 作用

HttpServletRequest 接口在 Java Servlet API 中扮演着至关重要的角色&#xff0c;它是 Servlet 处理客户端 HTTP 请求的核心对象。 每次客户端&#xff08;例如浏览器&#xff09;向服务器发送一个 HTTP 请求时&#xff0c;Servlet 容器&#xff08;例如 Tomcat&#xff09;都…...

Python----PyQt开发(PyQt高级:手搓一个简单的记事本)

一、效果展示 二、设计PyQt界面 2.1、设置图标 self.setWindowIcon(QIcon(./images/icon/1.png)) # 窗口图标 2.2、设置标题 self.file_name 无标题-新建文本文档 # 默认文件名 self.setWindowTitle(self.file_name) # 窗口标题 2.3、添加菜单栏、工具栏、状态栏 # 创…...

MySQL 索引失效案例:字符集不匹配的隐蔽影响

引言 在 MySQL 数据库世界里&#xff0c;索引失效往往是性能问题的罪魁祸首。你是否曾遇到过这样的情况&#xff1a;明明加了索引&#xff0c;查询却慢如蜗牛&#xff1f;你是否曾以为小表查询就一定高效&#xff1f;本文将揭示一个真实的案例&#xff0c;一个容易被忽视的“隐…...

MySQL中类似PostgreSQL中的string_agg函数--GROUP_CONCAT函数的使用

文章目录 结论&#xff1a;MySQL没有string_agg&#xff0c;但有GROUP_CONCATGROUP_CONCAT函数的基本用法示例注意事项 系统变量 group_concat_max_len 如何查看和设置查看当前的group_concat_max_len值设置group_concat_max_len值 相关源码相关链接 结论&#xff1a;MySQL没有…...

科普:数据血缘理论中:任务血缘、表血缘、字段血缘

在讨论数据血缘时通常我们提到的是数据库血缘、数据表血缘和数据字段血缘&#xff0c;而“任务血缘”这一术语更多是在特定技术场景&#xff08;如实时任务运维&#xff09;中使用。 数据血缘分类 表血缘 表血缘&#xff08;或数据表血缘&#xff09;是指数据在不同数据表之…...

凸性相关问题

内容大致上包括&#xff1a; 四边形不等式&#xff0c;决策单调性闵可夫斯基和优化 d p dp dpslope trick 优化 d p dp dp其他凸性相关问题 决策单调性 1.1 一些约定 对于 n m n\times m nm 的矩阵 A A A&#xff0c;定义&#xff1a; 子矩阵 A [ i 1 , . . . , i p …...

WPS计算机二级•文档的文本样式与编号

听说这是目录哦 标题级别❤️新建文本样式 快速套用格式&#x1fa77;设置标题样式 自定义设置多级编号&#x1f9e1;使用自动编号&#x1f49b;取消自动编号&#x1f49a;设置 页面边框&#x1f499;添加水印&#x1fa75;排版技巧怎么分栏&#x1f49c;添加空白下划线&#x…...

开源堡垒机 JumpServer 社区版实战教程:一步步构建企业安全运维环境

文章目录 开源堡垒机 JumpServer 社区版实战教程&#xff1a;一步步构建企业安全运维环境一、访问JumpServer1.1 登录1.2 功能模块1.3 系统设置1.3.1 基本设置1.3.2 邮件设置 二、用户管理2.1 场景2.2 创建用户2.3 用户登录密码重置 三、资产管理3.1 准备工作3.2 登录控制台3.3…...

二、数据类型、运算符

1. 数据的表示详解 1.1 算术运算符 整数在计算机中的存储原理先从最基本的算术运算符开始学习&#xff0c;算术运算符有 - * / % &#xff0c;其中*表示乘法&#xff0c;/表示除法&#xff0c;%表示取余数 需要我们注意以下几点 /: 两个整数相除&#xff0c;结果也是一个…...

结构形模式---桥接模式

概念 桥接模式是一种结构化模式&#xff0c;是将一个大类或者一系列的紧密相关的类拆分为抽象和现实两个独立部分的层次结构&#xff0c;通过引用独立层次对象的组合实现类。 桥接模式可以将庞杂类拆分为几个类层次结构。 此后&#xff0c; 你可以修改任意一个类层次结构而不…...

计算机网络知识速记:HTTP1.0和HTTP1.1

计算机网络知识速记&#xff1a;HTTP1.0和HTTP1.1 1. 基本概念 1.1 HTTP1.0 HTTP1.0是1996年发布的第一个正式版本&#xff0c;主要用于客户端与服务器之间的简单请求和响应交互。它的设计理念相对简单&#xff0c;适合处理一些基本的网页服务。 1.2 HTTP1.1 HTTP1.1是HTT…...

Windows下查看WIFI密码

目录 命令行查看历史WIFI netsh wlan show profiles 命令行查看某一特定WIFI密码 netsh wlan show profile name “WIFI名” keyclear 打开命令行https://blog.csdn.net/weixin_70822378/article/details/145598560?spm1001.2014.3001.5502 命令行查看历史WIFI nets…...

Android车机DIY开发之软件篇(十二) AOSP12下载编译

Android车机DIY开发之软件篇(十二) AOSP12下载编译 sudo apt-get update sudo apt-get install git-core gnupg flex bison gperf build-essential zip curl zlib1g-dev gcc-multilib gmultilib libc6-dev-i386 lib32ncurses5-dev libx11-dev lib32z-dev ccache libgl1-mesa-…...

Datawhale Ollama教程笔记2

本期学习易错点&#xff1a; 改文件后缀 改了models的存储地址后&#xff0c;把下载和新建的文件存储在什么地方 注册hugging face,找到token. 学习手册&#xff1a;https://datawhalechina.github.io/handy-ollama/#/ 第 3 章 自定义导入模型https://datawhalechina.gith…...

ClickHouse的前世今生

ClickHouse是一款由Yandex开发的高性能列式存储数据库管理系统,专为在线分析处理(OLAP)设计,适用于实时数据分析、大规模数据处理和复杂查询场景。以下是关于ClickHouse的安装、使用及应用场景的详细介绍: 一、ClickHouse的安装 ClickHouse支持多种操作系统,包括Linux、…...

SSH隧道+Nginx:绿色通道详解(SSH Tunnel+nginx: Green Channel Detailed Explanation)

SSH隧道Nginx&#xff1a;内网资源访问的绿色通道 问题背景 模拟生产环境&#xff0c;使用两层Nginx做反向代理&#xff0c;请求公网IP来访问内网服务器的网站。通过ssh隧道反向代理来实现&#xff0c;重点分析一下nginx反代的基础配置。 实验环境 1、启动内网服务器的tomca…...

html文件怎么转换成pdf文件,2025最新教程

将HTML文件转换成PDF文件&#xff0c;可以采取以下几种方法&#xff1a; 一、使用浏览器内置功能 打开HTML文件&#xff1a;在Chrome、Firefox、IE等浏览器中打开需要转换的HTML文件。打印对话框&#xff1a;按下CtrlP&#xff08;Windows&#xff09;或CommandP&#xff08;M…...

大促备战中稳定性建设策略与总结

文章目录 接口流量评估、上下游依赖梳理降级能力建设应急响应预案建设压力测试监控报警建设容灾演练 之前也专门写过日常稳定性建设的一些策略&#xff0c;传送门 -> 日常稳定性建设策略与总结&#xff0c;本文想专门聊聊大促期间做的一些稳定性保障&#xff0c;顺便记录自己…...

vscode/cursor+godot C#中使用socketIO

在 Visual Studio Code(VS Code)中安装 NuGet 包&#xff08;例如SocketIOClient&#xff09;&#xff0c;你可以通过以下几种方法&#xff1a; 方法 1&#xff1a;使用dotnet cli 打开终端&#xff1a;在 VS Code 中按下Ctrl 或者通过菜单View -> Terminal打开终端。 导…...

Uniapp 原生组件层级过高问题及解决方案

文章目录 一、引言&#x1f3c5;二、问题描述&#x1f4cc;三、问题原因❓四、解决方案&#x1f4af;4.1 使用 cover-view 和 cover-image4.2 使用 subNVue 子窗体4.3 动态隐藏原生组件4.4 使用 v-if 或 v-show 控制组件显示4.5 使用 position: fixed 布局 五、总结&#x1f38…...

jQuery介绍(快速、简洁JavaScript库,诞生于2006年,主要目标是简化HTML文档操作、事件处理、动画和Ajax交互)

文章目录 **核心功能 & 亮点**1. **简化 DOM 操作**2. **链式调用**3. **跨浏览器兼容**4. **便捷的事件绑定**5. **Ajax 封装**6. **动画效果** **现状与适用场景**- **传统项目维护**&#xff1a;许多旧系统&#xff08;如 WordPress 插件、老企业网站&#xff09;仍依赖…...

第三节 docker基础之---Commit+Dockerfile制作

docker目前镜像的制作两种方法&#xff1a; 1&#xff0c;基于docker Commit制作镜像 2&#xff0c;基于dockerfile制作镜像&#xff0c;Dockerfile 为主流的制作方式 如果不制作镜像删除容器之后则里面配置的文件也随之删除&#xff1a; [rootdocker ~]# docker images 查看…...

通过openresty和lua实现随机壁纸

效果&#xff1a; 图片存放路径&#xff1a; /home/jobs/webs/imgs/ ├── default/ │ ├── image1.jpg │ ├── image2.png ├── cats/ │ ├── cat1.jpg │ ├── cat2.gif ├── dogs/ │ ├── dog1.jpg访问http://demo.com/imgs/default 随机返回…...

企业网站如何快速实现全站HTTPS安全访问?

当用户访问您的网站时&#xff0c;若您的企业网站仍以HTTP协议运行&#xff0c;浏览器“不安全”警告不仅会吓退潜在客户&#xff0c;还会拖累搜索引擎排名&#xff0c;直接影响业务转化和品牌声誉。实现全站HTTPS安全访问&#xff0c;已成为企业网站运营的必选项。 本文为您详…...

《花未眠》夜间四时醒来,海棠花未眠

《花未眠》夜间四时醒来&#xff0c;海棠花未眠 川端康成&#xff08;1899-1972&#xff09;日本作家。新感觉派。1968年以“敏锐的感受&#xff0c;高超的叙事技巧&#xff0c;表现日本人的精神实质”获诺贝尔文学奖。诺贝尔文学奖提名作有《雪国》《千羽鹤》《古都》。 陈德文…...