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

【复习】最小生成树 Kruskal

‍ 关于作者会编程的土豆“不是因为看见希望才坚持而是坚持了才看见希望。”你好我是会编程的土豆一名热爱后端技术的Java学习者。正在更新中的专栏《数据结构与算法》《leetcode hot 100》《数据库mysql》作者简介后端学习者经典模版#includeiostream #includevector #includealgorithm using namespace std; typedef struct node { int u, v, w; }node; vectornodeedges; vectorintparent; bool f(node a, node b) { return a.w b.w; } int find(int x) { if (parent[x] ! x) { parent[x] find(parent[x]); } return parent[x]; } int main() { int N, M; cin N M; edges.resize(M); parent.resize(N1); for (int i 1; i N; i) { parent[i] i; } for (int i 0; i M; i) { cin edges[i].u edges[i].v edges[i].w; } sort(edges.begin(), edges.end(), f); long long sum 0; long long use 0; for (int i 0; i M; i) { int rootu find(edges[i].u); int rootv find(edges[i].v); if (rootu ! rootv) { use; sum edges[i].w; parent[rootu] rootv; if (use N - 1) break; } } if (use N - 1) { cout sum endl; } else cout orz endl; return 0; }需要注意的是find函数返回的是parent[x]而不是x;中间那个是findparent[x];做题做题#includeiostream #includevector #includealgorithm using namespace std; typedef struct node { int u, v, w; }node; bool f(node a, node b) { return a.w b.w; } vectorintparent; vectornodearr; int find(int x) { if (parent[x] ! x) { parent[x] find(parent[x]); } return parent[x]; } int main() { int A, B; cin A B; parent.resize(B 1); for (int i 1; i B; i) { parent[i] i; } for (int i 1; i B; i) { arr.push_back({ 0,i,A }); } for (int i 1; i B; i) { for (int j 1; j B; j) { int k; cin k; if (i j k0) { arr.push_back({ i,j,k }); } } } sort(arr.begin(), arr.end(), f); long long sum 0; long long use 0; for (int i 0; i arr.size(); i) { int u arr[i].u; int v arr[i].v; int w arr[i].w; int rootu find(u); int rootv find(v); if (rootu ! rootv) { parent[rootu] rootv; sum w; use; if (use B) { break; } } } cout sum endl; }这个非常有意思刚开始根本没看出是最小生成树但是现在一想他这个还是那个样式就是这个礼物和另外一个礼物之间有个权值就像一个节点和一个节点之间的权值是一样的然后这个有个不一样那个的地方他有个初始化的价格就是这个价格不受任何别的物品的影响这个咱们就当做是节点0和当前节点之间的权值然后把他们全部加进一个数组按照那个权值w排序找出最小的一个个并查集加入然后就是可能会有疑问诶这个0明明是自己创建的虚拟节点为什么也要加入并查集假如0,2买过了遇到1,2还会再次购买吗问的很好so nace首先0必须要加入虚拟节点的咱们举个例子假如0,2也就是原价更加便宜先把原价买了0,2现在在同一个并查集了然后因为原价不是便宜吗哈哈哈所以下一个要遍历的还是0X这种然后才到1,2也就是0,1肯定子啊1,2前面0,1之后0和1就在一个并查集了而0,2也在所以1,2就在一个并查集了所以1,2不会被购买

相关文章:

【复习】最小生成树 Kruskal

👨‍💻 关于作者:会编程的土豆 “不是因为看见希望才坚持,而是坚持了才看见希望。” 你好,我是会编程的土豆,一名热爱后端技术的Java学习者。 📚 正在更新中的专栏: 《数据结构与算…...

BCI竞赛实战:从BCI competition IV 2b数据集的批量加载到PyTorch数据管道构建

1. BCI竞赛与数据集背景 脑机接口(BCI)竞赛是推动脑电信号处理技术发展的重要平台,其中BCI Competition IV 2b数据集因其规范的采集流程和明确的运动想象任务设计,成为入门级研究的理想选择。这个数据集包含9名受试者的左右手运动…...

Play Integrity API Checker:Android设备安全检测的终极指南

Play Integrity API Checker:Android设备安全检测的终极指南 【免费下载链接】play-integrity-checker-app Get info about your Device Integrity through the Play Intergrity API 项目地址: https://gitcode.com/gh_mirrors/pl/play-integrity-checker-app …...

DeepAnalyze在教育领域的个性化学习应用

DeepAnalyze在教育领域的个性化学习应用 1. 当作业不再只是对错判断,而是学习路径的起点 你有没有遇到过这样的情况:学生交上来一份开放性题目答案,内容丰富但思路跳跃,老师批改时反复斟酌——这算对还是不对?该给多…...

EF Core 拦截器实战:SaveChangesInterceptor、CommandInterceptor 与审计落地缕

一、背景与问题缘起 MySQL 5.6.51 版本下 2000 万行核心业务表开展新增字段操作,需求为新增BIGINT(19) NOT NULL DEFAULT 0 COMMENT 注释(因业务实际需要存储大数值关联字段)。 表的核心特性为Java 多线程密集读写,业务请求持续高…...

AI智能二维码工坊开发手册:REST API接口调用示例

AI智能二维码工坊开发手册:REST API接口调用示例 1. 项目概述 AI智能二维码工坊是一个基于Python QRCode和OpenCV构建的全能型二维码处理工具。它采用纯算法逻辑实现,提供高性能的二维码生成与识别解码服务,支持高容错率编码,无…...

打字不如说话,说话不如截图——AI 代码助手的多模态输入实践澜

整体排查思路 我们的目标是验证以下三个环节是否正常: 登录成功时:服务器是否正确生成了Session并返回了包含正确 JSESSIONID的Cookie给浏览器。 浏览器端:浏览器是否成功接收并存储了该Cookie。 后续请求:浏览器在执行查询等操作…...

VSCode里那个烦人的Delete ␍ prettier报错,我是这样一键解决的

VSCode里那个烦人的Delete ␍ prettier报错,我是这样一键解决的 每次在VSCode里保存文件时,右下角突然蹦出那个"Delete ␍ prettier/prettier"的红色报错,你是不是也和我一样感到烦躁?作为一个长期在Windows和Mac之间切…...

有没有一款工具可以一键降低重复率和AI相似度?

毕业季论文查重、AI 检测双重高压?重复率居高不下、AI 痕迹太明显反复被打回?别再熬夜逐字改写!PaperRed、毕业之家、豆包、DeepSeek、QuillBot 五大王牌工具,搭载语义重构 AI 痕迹消除双引擎,真正实现一键降低重复率…...

后悔没早用!这 4 个工具同时降低重复率和 AI 率,太省心了!

2026 年学术审核进入 “双重严查” 时代,知网、维普等平台不仅严控重复率,更对 AIGC 生成痕迹零容忍,AI 率超标同样判定为学术不端。一边改重复率、一边消 AI 痕迹,反复折腾还总翻车?别再盲目试错!实测精选…...

Windows与Office激活革命:KMS_VL_ALL_AIO智能解决方案深度解析

Windows与Office激活革命:KMS_VL_ALL_AIO智能解决方案深度解析 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 你是否曾为Windows系统或Office办公软件那恼人的"需要激活"…...

避坑指南:Alist挂载夸克网盘常遇到的5大问题(Cookie失效/播放卡顿/刮削失败)

Alist挂载夸克网盘实战:5大高频问题解决方案与性能优化指南 1. Cookie失效的自动化解决方案 夸克网盘的Cookie失效问题堪称Alist用户最头疼的挑战。不同于其他网盘,夸克对登录状态的检测更为严格,常规手动更新方式效率极低。经过三个月持续…...

pg_service.conf:你团队遗忘的魔法

pg_service.conf:你团队遗忘的魔法 摘要本文介绍 pg_service.conf,这是一个简单的 INI 格式配置文件,允许开发者为 PostgreSQL 定义命名的连接配置文件,无需记忆复杂的连接字符串,并通过配置文件中的统一服务别名实现…...

pg_column_size(): 眼见不一定为实

pg_column_size(): 眼见不一定为实 摘要本文探讨了 PostgreSQL 的 pg_column_size() 函数,并揭示了一个令人惊讶的行为:对于以行外方式存储的 TOASTed 值,该函数仅返回 18 字节的指针大小,而非实际数据大小,这可能导致…...

Java Iterator详解

Java Iterator详解 概述 Java的Iterator接口是Java集合框架中用于迭代(遍历)集合对象的一个接口。它提供了一种方式来遍历集合中的元素,而不需要暴露集合的内部结构。Iterator接口是Java集合框架中非常重要的一部分,它被广泛用于各种数据结构的遍历操作。 Iterator接口的…...

Git与GitHub:深入理解版本控制与代码托管

Git与GitHub:深入理解版本控制与代码托管 引言 在软件开发领域,版本控制和代码托管是至关重要的环节。Git和GitHub作为当前最流行的版本控制工具和代码托管平台,已经成为广大开发者必备的技能。本文将深入探讨Git和GitHub的基本概念、使用方法以及它们在软件开发中的重要性…...

避开Power BI数据导入的四大坑:从SQL Server连接到Excel表格的实战避坑指南

避开Power BI数据导入的四大坑:从SQL Server连接到Excel表格的实战避坑指南 当你第一次将SQL Server的销售数据与Excel的市场调研表格合并到Power BI时,那个红色感叹号就像一盆冷水浇下来——"查询超时"。这不过是数据工程师日常工作中的第一个…...

Android 4G上网协议解析:从PPP建立到数据传输全流程

1. Android 4G上网的硬件基础 当你用手机刷短视频时,有没有想过4G网络是怎么工作的?和家里WiFi不同,4G上网依赖的是基带模块这个"隐形英雄"。现代智能手机其实内置了两套网络硬件:WiFi模块用的是标准以太网卡&#xff0…...

锐捷交换机连接与故障排除实战指南

1. 锐捷交换机连接方式详解 第一次接触锐捷交换机的朋友可能会被各种连接方式搞晕,其实主要就两种场景:机房直连和远程调试。我管理过上百台锐捷设备,实测下来最稳定的还是控制台连接,不过具体用哪种方式得看现场条件。 先说说控制…...

CiteSpace 6.3.R1 从零到一:基于CNKI数据的科研图谱实战指南

1. CiteSpace入门:科研小白的知识图谱神器 第一次打开CiteSpace时,那个黑底红字的界面让我有点发怵——这玩意儿真能帮我写论文?但跟着导师操作了半小时后,我发现自己居然做出了能放进论文里的专业图谱。这款由陈超美教授开发的软…...

微信H5分享功能实战:从配置到卡片式分享的完整指南

1. 微信H5分享功能的核心原理 微信H5页面分享功能和小程序分享最大的区别在于触发方式。H5页面无法像小程序那样直接调用onShareAppMessage方法,而是需要用户主动点击右上角的菜单按钮才能触发分享。这个设计差异导致很多开发者第一次接触H5分享时会感到困惑。 微信…...

硬件加速与 OMX/Codec2:解密编解码器的底层世界

引言:那些"神秘"的 vendor 参数是怎么来的 用 MediaCodec 开发的时候,偶尔会看到这样的代码: format.setInteger("vendor.qti-ext-enc-ltr-count.num-ltr-frames", 4); format.setInteger("vendor.rtc-ext-enc-low-latency.enable", 1);这些…...

【GUI-Agent】阶跃星辰 GUI-MCP 解读---()---HITL(Human In The Loop)南

插件化架构 v3 版本最大的变化是引入了模块化插件系统。此前版本中集成在核心包里的原生功能,现在被拆分成独立的插件。 每个插件都是一个独立的 Composer 包,包含 Swift 和 Kotlin 代码、权限清单以及原生依赖。开发者只需安装实际用到的插件&#xff0…...

绝区零自动化助手终极指南:如何实现游戏全自动一条龙服务

绝区零自动化助手终极指南:如何实现游戏全自动一条龙服务 【免费下载链接】ZenlessZoneZero-OneDragon 绝区零 一条龙 | 全自动 | 自动闪避 | 自动每日 | 自动空洞 | 支持手柄 项目地址: https://gitcode.com/gh_mirrors/ze/ZenlessZoneZero-OneDragon 还在为…...

Phi-4-Reasoning-Vision实战案例:电商商品图深度分析+隐藏线索识别

Phi-4-Reasoning-Vision实战案例:电商商品图深度分析隐藏线索识别 1. 工具介绍 Phi-4-Reasoning-Vision是一款基于微软Phi-4-reasoning-vision-15B多模态大模型开发的高性能推理工具。它专为双卡4090环境优化,能够对图片进行深度分析并识别隐藏线索&am…...

GoCodingInMyWay俜

一、什么是 Q 饱和运算? 1. 核心痛点:普通运算的 “数值回绕” 普通算术运算(如 ADD/SUB)溢出时,数值会按补码规则 “回绕”,导致结果完全错误: 示例:int8_t 类型最大值 127 1 → 结…...

Cadence 17.4 原理图分页符实战:解决‘1 of 1’报错,搞定多页连接

Cadence 17.4 原理图分页符深度解析:从报错诊断到高效设计实践 在复杂电路设计领域,Cadence 17.4作为行业标杆工具,其原理图设计功能直接影响着工程师的工作效率和设计质量。而多页原理图连接问题,尤其是分页符(off-page)配置不当…...

大模型推理硬件选型别再拍脑袋!SITS2026专家提炼的7步决策法(含量化评分卡+国产替代适配度评估表)

第一章:SITS2026专家:大模型推理加速硬件选型 2026奇点智能技术大会(https://ml-summit.org) 大模型推理对硬件的吞吐、延迟、显存带宽与能效比提出严苛要求。SITS2026专家团队基于千余次真实场景基准测试(包括Llama-3-70B、Qwen2-57B、Phi-…...

ROS机器人开发避坑指南:搞定PC、树莓派与STM32的三角通信(含完整代码与配置)

ROS多设备通信实战:PC、树莓派与STM32的高效协同架构设计 在机器人开发领域,ROS(Robot Operating System)已成为事实上的标准框架。但当我们需要将不同架构的计算设备(如x86的PC、ARM的树莓派和嵌入式STM32&#xff09…...

深入解析AXI VDMA:视频流高效传输的关键技术

1. AXI VDMA:视频处理的"高速公路收费站" 想象一下早晚高峰的城市环线,成千上万辆汽车需要有序通过收费站。AXI VDMA(Video Direct Memory Access)在视频处理系统中扮演的角色,就像这个智能收费站系统——它…...