普利姆最小生成树算法 c++

普里姆(Prim)算法是一种用于在加权连通无向图中查找最小生成树(MST, Minimum Spanning Tree)的贪心算法。最小生成树是一个子图,它包括图中的所有顶点,并且边的总权重最小。该算法的基本思想是从一个顶点开始,逐步扩展生成树,直到包括所有顶点。

算法步骤

  1. 初始化

    • 从一个起始顶点 u 开始。
    • 初始化一个 closedge 数组,其中 closedge[i] 保存了从生成树到顶点 i 的最小权重的边和对应的生成树中的顶点。
    • 将所有顶点的初始权重设置为无穷大(INF),表示这些顶点还没有连接到生成树。
  2. 选择最小权重的边

    • 在每一步中,从 closedge 数组中选择具有最小权重的边,这条边将连接一个在生成树内的顶点和一个不在生成树内的顶点。
    • 将这个顶点和边加入生成树。
  3. 更新 closedge 数组

    • 以新加入生成树的顶点为基础,更新 closedge 数组中的边权重。如果新加入顶点与其他未加入生成树的顶点之间的边权重小于当前记录的权重,则更新它。
  4. 重复步骤2和3

    • 重复以上步骤,直到所有顶点都被加入生成树。

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

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

相关文章

java内存管理机制(二)-内存分配

在上一篇文章中,我们花了较大的篇幅去介绍了JVM的运行时数据区,并且重点介绍了栈区的结构及作用,在本文中,我们将主要介绍对象的创建过程及在堆中的分配方式。 对象的创建 在上文我们提过一些问题,你的对象是怎么new…

Pump.fun

Pump.fun 是一个专为 Meme 币设计的发布token的工具和社群平台,于2024年1月在Solana区块链上推出,随后扩展至以太坊Layer 2 Blast。它的核心价值在于简化了发币过程,降低了技术门槛,允许任何人以极低的成本(0.02SOL&am…

C# HTTP POST(System.Net.WebException:请求已中止:请求已被取消)

一.问题描述 最近在使用c# http post请求时&#xff0c;遇见了这种异常&#xff0c;大概异常提示如下 System.Net.WebException&#xff1a;请求已中止&#xff1a;请求已被取消&#xff0c;在数据写入前关闭了数据流 错误代码如下&#xff1a; /// <summary>/// 向指…

5.3.3、二维数组案例-考试成绩统计

代码 #include <iostream> using namespace std; #include <string>int main() {//二维数组案例-考试成绩统计//1、创建二维数组int scores[3][3] {{100,100,100},{90,50,100},{60,70,80},};string names[3] { "张三","李四","王五&quo…

基于星火大模型的群聊对话分角色要素提取挑战赛|#AI夏令营#Datawhale#夏令营-Lora微调与prompt构造

赛题连接 https://challenge.xfyun.cn/topic/info?typerole-element-extraction&optionphb Datawhale Al夏令营 零基础入门大模型技术竞赛 数据集预处理 由于赛题官方限定使用了星火大模型&#xff0c;所以只能调用星火大模型的API或者使用零代码微调 首先训练数据很少…

周志华机器学习西瓜书经典来袭!PPT+课件+南瓜书

南京大学教授&#xff0c;博士生导师&#xff0c;教育部“长江学者”特聘教授&#xff0c;国家杰出青年基金获得者&#xff01;周志华老师的头衔太多了&#xff01;相信每一个从事或爱好机器学习的朋友都知道周志华老师&#xff0c;尤其是他的那本经典巨作《机器学习》&#xf…

慧哥Saas充电桩开源平台 V2.5.5

文章目录 原地址&#xff1a;https://gitee.com/chouleng/cdzkjjh&#xff0c;更换新的地址如下 [点击此链接 https://gitee.com/chouleng/huili-cloud](https://gitee.com/chouleng/huili-cloud)一、产品功能部分截图1.手机端&#xff08;小程序、安卓、ios&#xff09;2.PC端…

华为云OBS 通过S3客户端访问

华为云好像没有对S3协议的支持说明其实底层是支持S3协议的。 使用S3的时候我们会需要endpoint&#xff0c;桶名字&#xff0c;region&#xff0c;AWS_ACCESS_KEY,AWS_SECRET_KEY 其中endpoint 就是图片中的&#xff0c;桶名字也很容易找到&#xff0c;region 就是你的endpoint…

博途TIA Portal「集成自动化软件」下载安装,TIA Portal 灵活多变的编程环境

在编程领域&#xff0c;博途TIA Portal以其卓越的编程工具和灵活多变的编程环境&#xff0c;为众多用户提供了前所未有的便利。这款软件不仅支持多种编程语言&#xff0c;如梯形图&#xff08;Ladder Diagram&#xff09;、功能块图&#xff08;Function Block Diagram&#xf…

CVE-2024-6387漏洞复现有没有会的并详细解答的?求指点

CVE-2024-6387漏洞复现有没有会的并详细解答的&#xff1f;求指点

使用 gdb 脚本捕获 crash 时的 stack

crashreport.gdb 在看TrinityCore代码时&#xff0c;看到一段有趣的脚本(crashreport.gdb)&#xff1a; set logging overwrite on set logging file backtrace.log.temp set style enabled off set height unlimited set width unlimited set disassembly-flavor intel hand…

华为HCIP Datacom H12-821 卷24

1.单选题 企业大楼有大量员工通常都在上班时在大厅开始接入到公司的WLAN网络,随着每位员工走到各自的工位过程中&#xff0c;每个人的移动端叶通过漫游的方式漫游到各自的网络覆盖区域。为了尽量保证每个终端的IP地址是固定的&#xff0c;建议的做法是? A、配置VLAN Poo…

统计信号处理基础 习题解答11-13

题目 如果是一个2x1的随机矢量&#xff0c;具有PDF 证明的PDF是一个随机变量。提可以因式分解成&#xff0c;其中是一个在4.5节描述的白化变换。 解答 首先&#xff1a; 因此&#xff0c;存在&#xff1a; 也就是是Hermitian矩阵。详细的性质可以参考&#xff1a; https://z…

抠图怎么抠?教你3种一看就会的抠图工具

抠图怎么抠&#xff1f;抠图&#xff0c;作为图像处理中的一项基本而强大的技能&#xff0c;广泛应用于摄影后期、广告设计、影视特效等多个领域。它能够将图像中的特定对象或区域从背景中精确分离出来&#xff0c;便于后续编辑或与其他图像合成。随着科技的发展&#xff0c;现…

大模型技术方向夏令营1期-对话分角色要素提取挑战赛

#AI夏令营 #Datawhale #夏令营 一、 baseline 跑通 Baseline 本身挑战性有限&#xff0c;关键是熟悉 LLM-centric 相关任务 coding 层面的流程方法&#xff0c;比如: 大模型 API&#xff08;这里为科大讯飞 Spark&#xff09;调用token消耗的理解如何调用大模型实现针对给定…

个人PayPal账户与企业PayPal账户:差异与选择

PayPal作为全球领先的在线支付平台&#xff0c;为不同用户群体设计了两种类型的账户&#xff1a;个人账户和企业账户&#xff0c;不仅为个人用户提供了便捷的支付和收款服务&#xff0c;同时也为企业用户提供了丰富的电子商务解决方案&#xff0c;让个人和企业都能使用便捷的电…

【Nginx】学习及相关题目整理

文章目录 1. 什么是Nginx&#xff1f;2. Nginx有哪些优点&#xff1f;3. Nginx处理请求流程&#xff1f;4. Nginx应用场景5. Nginx是如何实现高并发的&#xff1f;6. 什么是正向代理&#xff1f;7. 什么是反向代理&#xff1f;8. 反向代理服务器的优点是什么?9. Nginx目录结构…

android Gradle储蓄地址

在使用 Gradle Wrapper 时&#xff0c;Gradle 分发版&#xff08;distribution&#xff09;会下载并存储在本地计算机的特定目录下&#xff0c;以便在将来使用相同版本的 Gradle 时无需重新下载。默认情况下&#xff0c;Gradle 分发版存储在用户的主目录下。 默认存储位置 默…

实现高效写入:Schemaless 写入性能优化指南

物联网应用常常需要收集大量的数据&#xff0c;用以支持智能控制、业务分析和设备监控等功能。然而&#xff0c;应用逻辑的更新或硬件的调整可能会导致数据采集项频繁变化&#xff0c;这是时序数据库&#xff08;Time Series Database&#xff0c;TSDB&#xff09;面临的一大挑…

vue中自定义设置多语言,并且运行js脚本自动生成多语言文件

在项目中需要进行多个国家语言的切换时&#xff0c;可以用到下面方法其中一个 一、自定义设置多语言 方法一: 可以自己编写一个设置多语言文件 在项目新建js文件&#xff0c;命名为&#xff1a;language.js&#xff0c;代码如下 // language.js 文档 let languagePage {CN…