图论算法:普里姆算法(C++实现+图解)

news2025/1/11 12:59:08

文章目录

  • 最小生成树
  • 普里姆算法
    • 实现过程
    • 代码实现

最小生成树

什么是最小生成树?

对于如图所示的带权无向连通图来说:从图中任意顶点出发,进行dfs或者bfs便可以访问到图中的所有顶点,因此连通图中一次遍历所经过的边的集合以及图中所有顶点的集合就构成了该图的一颗生成树。

其中把具有权之和最小的生成树叫做最小生成树。

如图中: 红色线表示的就是这棵树的最小生成树。

在这里插入图片描述

最小生成树可以应用到许多实际生活中,比如说求 用尽可能小的造价修建若干条高速公路,求 n个城市连接在一起的最短路径等等。。


普里姆算法

普里姆算法是一种构造性算法,用于求得一个带权无向连通图的最小生成树

普里姆算法规定:

  1. G = (V,E) 是一个带权无向联通图。 V表示图中的所有顶点集合,E表示点与边之间的关系
  2. T=(U,TE)是一颗最小生成树。U表示最小生成树的点的集合,TE表示最小生成树中的边集合。

假设我们要从 s点出发构建一颗最小生成树:

  1. 把s点加入U中,与s相邻的所有边作为侯选边,选出所有侯选边中权值最小的边,并且把这条边所在的V中的顶点加入到U中,并且把这个权值最小的边加入到TE中。
  2. 更新最小生成树的U与带权无向连通图的V-E,同时修改候选边:考察在V-E中所有顶点,把具有最小权值的边取代之前的候选边,然后重复步骤1.

图解步骤:
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

实现过程

我们使用两个辅助数组:
closest 与 lowcost

在这里插入图片描述

closest表示在U(最小生成树的顶点集合)中存储的顶点编号
lowcost表示存储该边的权值最小值

在这里插入图片描述

由此:

  • closest[i] = p: 表示 p -> i 这两个点
  • lowcost[i]:s->i这两个点所表示的边的权值。

实现过程:

  1. U(s) V-E(1,2,3,4) 从V-E顶点中选择一个lowcost[i]最小的点,这个点 i 就是第一次找到的点,图中即 i=1,即构造了最小生成树(0,1),将顶点i 加入到U中,然后置lowcost[i] 为零,表示已经找到这个点了。

  2. 然后修正这两个数组: 修正后如下:
    在这里插入图片描述

  3. 然后重复在V-E(2,3,4)中找到lowcost[i]最小的点,为lowcost[2] =3 ,此时i=2,然后以这个点构造第二条边:U(0,1,2),将顶点 i加入到U中,置lowcost[i]=0,然后修正数组,重新执行上面的操作

代码实现

首先要构建邻接矩阵:关于邻接矩阵与邻接表:
邻接矩阵与邻接表

普里姆算法:Prim

#include <iostream>
#include <string>
using namespace std;

constexpr const auto INF = 0x3f3f3f3f;
#define MAXN 100
//点集合
struct Vetrix
{
	int id;
	string info;
};
struct Graph
{
	int n, e;	//n:点数  e:边数
	int edge[MAXN][MAXN];	//边集合
	Vetrix v[MAXN];			//点集合
};

//创建邻接矩阵
void createGraph(Graph& g, int A[][5], int n, int e)
{
	g.e = e;
	g.n = n;
	for (int i = 0; i < n; i++)
	{
		for (int j = 0; j < n; j++)
		{
			g.edge[i][j] = A[i][j];
		}
	}
}

//普里姆算法
void Prim(Graph& g, int u)
{
	//以u为最小生成树的起点

	//两个辅助数组
	int closest[MAXN], lowcost[MAXN];
	for (int i = 0; i < g.n; i++)
	{
		closest[i] = u;				//i: 顶点	
		lowcost[i] = g.edge[u][i];	edge[u][i]: u->i 这条边所具有的权值
	}
	int min, k;
	for (int i = 1; i < g.n; i++)
	{
		min = INF, k = -1;
		for (int j = 0; j < g.n; j++)
		{
			//lowcost[j] != 0 表示所选的点不能是U中的点,只能是V-E中的
			//lowcost[j] < min 表示依次选取权值最小的边
			if (lowcost[j] != 0 && lowcost[j] < min)	//在V-E中找出离U最近的顶点
			{
				min = lowcost[j];	
				k = j;				//k为最近顶点编号
			}
		}
		//k:记录了权值最小的边在V-E中的顶点编号
		//min:记录了这个最小权值
		printf(" 边(%d -> %d) 权值:%d\n", closest[k],k, min);
		//修正数组
		lowcost[k] = 0;	//这个边已经选过了
		for (int j = 0; j < g.n; j++)
		{
			//以k作为起点,寻找与k点连接的边的权值是否比之前记录的权值小
			if (lowcost[j] != 0 && g.edge[k][j] < lowcost[j])
			{
				lowcost[j] = g.edge[k][j];	//更新为最小权值
				closest[j] = k;				//记录这个点
			}
		}
	}
}

int main()
{
	Graph g;
	int n = 5, e = 8;
	int A[][5] = {
		{0,1,3,4,7},
		{1,0,2,INF,INF},
		{3,2,0,5,8},
		{4,INF,5,0,6},
		{7,INF,8,6,0}
	};
	createGraph(g, A, n, e);
	Prim(g, 0);
	return 0;
}

运行如下:

在这里插入图片描述

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

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

相关文章

libvirt零知识学习2 —— libvirt源码下载

1. libvirt官网主页 libvirt的官网地址为&#xff1a; https://libvirt.org/ 主页如下图所示&#xff1a; 2. libvirt官网下载主页 libvirt的官网下载页地址为&#xff08;在主页中点击“Download”按钮即可跳转到&#xff09;&#xff1a; https://libvirt.org/downloads…

KaiwuDB 首席解决方案专家 金宁:1.0 时序数据库核心功能解读

以下是实录文章精简版欢迎大家点赞、收藏、关注&#xff01;大家好&#xff0c;今天介绍将分为 3 部分&#xff1a;首先从物联网蓬勃发展的时代背景出发&#xff0c;我们一起来看看数据库究竟将面临怎样的挑战与机遇&#xff1b;接着我将为大家详细 KaiwuDB 1.0 时序数据库的核…

(Java高级教程)第四章必备前端基础知识-第一节:HTML

文章目录一&#xff1a;HTML概述&#xff08;1&#xff09;概述&#xff08;2&#xff09;标签&#xff08;3&#xff09;HTML基本结构二&#xff1a;常用标签介绍&#xff08;1&#xff09;注释&#xff08;2&#xff09;标题&#xff08;3&#xff09;段落&#xff08;4&…

React Fragment

首先 我们编写这样一个例子 我们在创建一个react项目 在src的目录下创建components目录 components下创建一个子组件 我这里的名字叫 subset.jsx import React from "react";export default class subset extends React.Component{constructor(props){super(prop…

阿B百大名单公布,有你喜欢的up吗?

阿B在1月13日中午19点30分公布了2022百大UP主名单&#xff0c;那么今年的某站年度UP主都是谁呢&#xff1f;你喜欢的up入选了吗&#xff1f; 咱就来自己查一下都有谁入选了吧~ 我们是用python自动获取名单的哦。 环境使用 python 3.9 pycharm 模块使用 selenium 谷歌驱动 …

Java基础之《netty(26)—netty其他常用编解码器》

一、解码器-ReplayingDecoder 1、函数声明 public abstract class ReplayingDecoder<S> extends ByteToMessageDecoder 2、ReplayingDecoder扩展了ByteToMessageDecoder类&#xff0c;使用这个类&#xff0c;我们不必调用readableBytes()方法。参数S指定了用户状态管理…

【Linux】版本管理工具 Git

目录 一、什么是 Git 二、如何使用 Git 1、创建远程仓库 2、将远端仓库克隆到本地 3、将本地文件添加到仓库 3.1、三板斧第一招&#xff1a;文件添加 3.2、三板斧第二招&#xff1a;提交本地 3.3、三板斧第三招&#xff1a;提交远端 4、删除文件 5、删除仓库 一、什么是 Gi…

postman接口关联

有两种方法&#xff0c;使用json提取器实现接口关联&#xff0c;还有使用正则表达式提取器实现接口关联。方法一&#xff1a;使用json提取器实现接口关联第一个接口&#xff1a;//使用json提取器提取contractID、documentID//把返回的字符串格式的数据转换成对象的形式var resu…

SAP FICO 理解成本中心会计

成本中心会计 一、成本要素 管理会计&#xff08;CO&#xff09;的数据均来源于FI损益类科目&#xff0c;也就是说只有损益类科目才可以创建成本要素&#xff08;必须先创建损益类科目&#xff0c;后创建成本要素&#xff09;&#xff0c; 但是不一定所有的损益类科目都需要…

gma 气象气候函数包的简要介绍及运算过程主要问题说明(内存不足、出现 nan 等)及解决方法

0 概述 0.1 明确气候与气象的概念 气候(Climate)&#xff1a;是指一个地区大气物理特征的长期平均状态&#xff0c;具有一定的稳定性&#xff0c;且周期长。根据世界气象组织&#xff08;WMO&#xff09;的规定&#xff0c;一个标准气候计算时间为 30 年。 气象(Meteorology)&…

【论文笔记】一文读懂残差网络ResNet(附代码)

Residual Net论文笔记1. 传统深度网络的问题2. 残差结构和残差网络2.1 残差是什么2.2 残差模块 Residual Block2.3 基本模块BasicBlock和BottleNeck2.4 残差网络ResNet设计2.4.1 恒等映射与残差的连接3. Forward/Backward Propagation3.1 Forward propogation3.2 Back Propogat…

深信服行为感知命令执行漏洞

深信服行为感知命令执行漏洞1.深信服行为感知漏洞1.1.漏洞描述1.2.漏洞影响1.3.漏洞复现1.3.1.登录页面1.3.2.构建漏洞URL1.3.2.1.查询IP地址1.3.2.2.查询当前目录下文件1.深信服行为感知漏洞 1.1.漏洞描述 深信服 行为感知系统c.php远程命令执行漏洞&#xff0c;使用与EDR相同…

Docker搭建kafka集群

Docker搭建kafka集群集群规划镜像版本kafka为什么需要依赖zookeeper创建docker网络搭建zk集群新建文件docker-compose-zk.yml启动搭建kafka集群新建docker-compose-kafka.yml启动集群安装kafka-manager新建 docker-compose-kafka-manager.yml启动kafka-manager配置cluster修改k…

Pandas 数据结构 - DataFrame

Pandas 数据结构 - DataFrameDataFrame 是一个表格型的数据结构&#xff0c;它含有一组有序的列&#xff0c;每列可以是不同的值类型&#xff08;数值、字符串、布尔型值&#xff09;。DataFrame 既有行索引也有列索引&#xff0c;它可以被看做由 Series 组成的字典&#xff08…

nexus3 搭建maven私服

首先下载nexus3安装包 这里使用linux版, 需要win或mac版请自行百度 链接&#xff1a;https://pan.baidu.com/s/11Z_884pt11l04460ldUyVA?pwdycuo 提取码&#xff1a;ycuo 上传linux服务器进行解压缩 解压缩后的文件目录 进入到 nexus的执行目录 /nexus-3.31.1-01/bin 运行…

Qt 6.x中的信号和槽介绍及示例

信号(signals)和槽(slots)用于对象之间的通信&#xff0c;Qt使用信号和槽完成了事件监听操作。信号和槽机制是Qt的核心特性&#xff0c;可能也是与其它框架提供的特性最大的不同之处。信号和槽是通过Qt的元对象系统(Meta-Object system)实现的&#xff0c;Qt的元对象系统使信号…

【寒假每日一题】DAY.10 杨辉直角(等腰)三角

目录 一、杨辉直角三角 思路 按部就班 代码实现 二、杨辉等腰三角 注&#xff1a;由于VS不支持变长数组&#xff0c;这里我就用n4来写 一、题目名称 题目内容&#xff1a; 输入一个数n&#xff0c;在屏幕上打印n行n列的杨辉三角。例如&#xff1a;输入&#xff1a;4输出&am…

CSRF与XSS组合拳

目录 先介绍下这两个漏洞&#xff1a; CSRF XSS 实验&#xff1a; 环境&#xff1a; CSRF与反射型xss的第一拳 CSRF与存储型XSS的第二拳&#xff1a; 先介绍下这两个漏洞&#xff1a; CSRF CSRF是跨站请求伪造攻击&#xff0c;由客户端发起,是由于没有在关键操作执行时进…

美团滑块(1-18,js逆向)

网址&#xff1a;aHR0cHM6Ly9wYXNzcG9ydC5tZWl0dWFuLmNvbS9hY2NvdW50L3VuaXRpdmVsb2dpbg整体流程&#xff1a; 1、获取主页参数 2、逆向pwd、h5Fingerprint 3、请求page_data链接 4、逆向Authencation、behavior、token_ 5、最终请求验证一、获取主页参数 url_ "https:/…

信息论复习—信息论的基本概念

信息的概念&#xff1a;古代的信息技术&#xff1a;现代的信息技术信息与消息的关系&#xff1a;消息&#xff1a;用文字、符号、数据、语言、音符、图片、图像等能够被人们感觉器官所感知的形式&#xff0c;把客观物质运动和主观思维活动的状态表达出来就称为消息。信息&#…