Prim算法实现最小生成树

news2024/11/25 20:36:56

Prim算法是一种用来寻找图的最小生成树的贪心算法。最小生成树是连接图中所有顶点的边的子集,这些边的权重总和最小,且形成一个树形结构,包含所有顶点。

Prim算法的基本步骤如下:

  1. 初始化
    • 选择任意一个顶点作为起始点(通常选择第一个顶点)
    • 创建一个优先队列(最小堆)来存储顶点和它们当前的最小边权重。
    • 创建一个集合来记录已经加入最小生成树的顶点。
  2. 生长最小生成树
    • 从优先队列中取出权重最小的顶点(如果存在)
    • 将该顶点加入最小生成树集合
    • 更新与该顶点相邻的顶点的权重,如果通过当前顶点可以找到更短的路径到达这些顶点,则更新它们的权重
  3. 重复
    • 重复步骤2,直到所有顶点都被加入最小生成树集合
  4. 输出
    • 最小生成树的总权重是优先队列中所有被取出的边的权重之和

在这里插入图片描述

#include <iostream>
#include <vector>
#include <climits>


const int MAX_VERTICES = 100;  // 最大顶点数
const int INF = INT_MAX;  // 表示不可达


// 使用邻接矩阵表示无向图
class UndirectedGraph {
public:
    int vertex_number;  // 顶点数
    std::vector<std::vector<int>> adjacency_matrix;  // 邻接矩阵

    // 构造函数,并将参数赋值给成员变量
    UndirectedGraph(int val) : vertex_number(val), adjacency_matrix(val, std::vector<int>(val, INF)) {
        // 查看邻接矩阵的初始值,并无实际意义
        for (int i = 0; i < adjacency_matrix.size(); ++i) {
            for (auto value : adjacency_matrix[i]) {
                std::cout << value << " ";
            }
        }
        std::cout << std::endl;
    }
    
    // 添加边,传入三个参数,u和v是顶点,w为权重
    void add_edge(int u, int v, int w) {
        adjacency_matrix[u][v] = w;
        adjacency_matrix[v][u] = w;  // 如果是无向图,则需要添加这行
    }
};


// Prim算法实现
void prim_mst(const UndirectedGraph& graph) {
    int vn = graph.vertex_number;
    std::vector<int> key(vn, INF);  // 存储从集合外到集合内的最小权重
    std::vector<bool> in_mst(vn, false);  // 标记顶点是否已经在MST中
    std::vector<int> parent(vn, -1);  // 存储MST中的边的父顶点

    // 从第一个顶点开始构建MST
    key[0] = 0;  // 顶点0是起始点

    for (int count = 0; count < vn; ++count) {
        // 找到不在MST中且key值最小的顶点
        int u = -1;
        int min_weight = INF;
        for (int v = 0; v < vn; ++v) {
            if (!in_mst[v] && key[v] < min_weight) {
                u = v;
                min_weight = key[v];
            }
        }

        in_mst[u] = true;  // 将顶点u加入MST

        // 更新与顶点u相邻的顶点的key值
        for (int v = 0; v < vn; ++v) {
            if (graph.adjacency_matrix[u][v] && !in_mst[v] && graph.adjacency_matrix[u][v] < key[v]) {
                parent[v] = u;
                key[v] = graph.adjacency_matrix[u][v];
            }
        }
    }

    // 输出MST的详细信息
    int totalWeight = 0;
    for (int i = 1; i < vn; ++i) {
        std::cout << "Edge (" << parent[i]+1 << ", " << i+1 << ") -> Weight = " << graph.adjacency_matrix[parent[i]][i] << std::endl;
        totalWeight += graph.adjacency_matrix[parent[i]][i];
    }
    std::cout << "Total weight of MST = " << totalWeight << std::endl;
}

int main() {
    UndirectedGraph g(7);  // 实例化类对象

    // 构造无向有权图
    g.add_edge(0, 1, 2);
    g.add_edge(0, 2, 4);
    g.add_edge(0, 3, 1);
    g.add_edge(1, 3, 3);
    g.add_edge(1, 4, 10);
    g.add_edge(2, 3, 2);
    g.add_edge(2, 5, 5);
    g.add_edge(3, 4, 7);
    g.add_edge(3, 5, 8);
    g.add_edge(3, 6, 4);
    g.add_edge(4, 6, 6);
    g.add_edge(5, 6, 1);

    std::cout << "Following are the edges in the constructed MST:\n";
    prim_mst(g);

    return 0;
}
---------
Following are the edges in the constructed MST:
Edge (1, 2) -> Weight = 2
Edge (4, 3) -> Weight = 2
Edge (1, 4) -> Weight = 1
Edge (7, 5) -> Weight = 6
Edge (7, 6) -> Weight = 1
Edge (4, 7) -> Weight = 4
Total weight of MST = 16

在这里插入图片描述

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

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

相关文章

全栈开发要掌握的技术

文章目录 1、前端开发2、后台开发2.1 编程语言2.2 网络框架 3、数据库开发3.1 RDBMS3.2 NoSQL 数据库 4、移动开发4.1 本地开发4.2 跨平台开发 5、云计算5.1 云平台5.2 容器化和协调 6、用户界面/用户体验设计6.1 设计工具6.2 原型和线框图 7、基础设施和 DevOps7.1 基础设施即…

C语言读取data.json文件并存入MySQL数据库小案例

本地有一个data.json文件 data.json [{"id": 1,"name": "Alice","age": 30},{"id": 2,"name": "Bob","age": 25} ]要将 data.json 文件中的数据存储到 MySQL 数据库中&#xff0c;首先需要…

快速入门Tomcat服务(业务发布基础技能)

文章目录 1 Tomcat简介 2 安装tomcat 2.1 安装jdk 2.2 安装Tomcat 3 Tomcat目录结构 4 Tomcat重要配置文件 1 Tomcat简介 Tomcat是Sun公司官方推荐的Servlet和JSP容器&#xff0c;在中小型系统和并发访问用户不是很多的场合下&#xff0c;其作为轻量级应用服务…

如何在Node.js里实现依赖注入

什么是依赖注入 依赖注入是一种用于在开发过程中实现控制反转&#xff08;IoC&#xff09;的技术。在IoC中&#xff0c;对程序流的控制是颠倒的&#xff1a;依赖项不是控制其依赖项的创建和管理的组件&#xff0c;而是从外部源提供给组件。 在传统的编程模式中&#xff0c;一个…

【ECC校验及使用】

ECC校验及使用 1 RAM ECC Demo 在IC设计中会经常用到ram来进行存储&#xff0c;在存储数据时我们写读时需要知道在传输过程中有没有出现差错&#xff0c;因此需要额外的校验位也存储下来&#xff1b; ECC验证能纠正1bit错误&#xff0c;能发现2bit错误&#xff0c;但是无法纠正…

第十三章:监控过程组(13.1控制质量--13.7监督沟通)

前言&#xff1a; 监督 是收集项目绩效数据&#xff0c;计算绩效指标&#xff0c;并报告和发布绩效信息。 控制 是比较实际绩效与计划绩效&#xff0c;分析偏差&#xff0c;评估趋势以改进过程&#xff0c;评价可选方案&#xff0c;并建 议必要的纠正措施。 13.1 控制质量 本过…

数据库SQL基础教程(二)

目录 连接(JOIN) 语法&#xff1a; 不同的 SQL JOIN INNER JOIN 关键字 LEFT JOIN 关键字 SQL LEFT JOIN 语法 RIGHT JOIN 关键字 SQL RIGHT JOIN 语法 FULL OUTER JOIN 关键字 SQL FULL OUTER JOIN 语法 UNION 操作符 SQL UNION 语法 SQL UNION ALL 语法 SELECT I…

大数据毕业设计选题推荐-B站短视频数据分析系统-Python数据可视化-Hive-Hadoop-Spark

✨作者主页&#xff1a;IT毕设梦工厂✨ 个人简介&#xff1a;曾从事计算机专业培训教学&#xff0c;擅长Java、Python、PHP、.NET、Node.js、GO、微信小程序、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇…

软媒市场新蓝海:软文媒体自助发布与自助发稿的崛起

在信息时代的浪潮中,软媒市场以其独特的魅力和无限的潜力,成为了企业营销的新宠。随着互联网的飞速发展,软文媒体自助发布平台应运而生,为企业提供了更加高效、便捷的营销方式。而自助发稿功能的加入,更是让软媒市场的蓝海变得更加广阔。 软媒市场的独特价值 软媒市场之所以能…

YOLO_V8分割

YOLO_V8分割 YOLO安装 pip install ultralytics YOLO的数据集转化看csdn 数据标注EIseg EIseg这块&#xff0c;正常安装就好&#xff0c;但是numpy和各类包都容易有冲突&#xff0c;python版本装第一点 数据标注过程中&#xff0c;记得把JSON和COCO都点上&#xff0c;把自…

计算机毕业设计 基于Hadoop平台的岗位推荐系统的设计与实现 Python毕业设计 Python毕业设计选题【附源码+安装调试】

博主介绍&#xff1a;✌从事软件开发10年之余&#xff0c;专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精…

python脚本封装APK,轻松随意无须复杂配置

优点&#xff1a;轻松随意不设置&#xff0c;缺点&#xff1a;新用户试用&#xff0c;VI专属能力。 (笔记模板由python脚本于2024年10月11日 06:16:14创建&#xff0c;本篇笔记适合“资深”编程的coder翻阅) 【学习的细节是欢悦的历程】 Python 官网&#xff1a;https://www.py…

基于Springboot+Vue的网上订餐系统(含源码数据库)

1.开发环境 开发系统:Windows10/11 架构模式:MVC/前后端分离 JDK版本: Java JDK1.8 开发工具:IDEA 数据库版本: mysql5.7或8.0 数据库可视化工具: navicat 服务器: SpringBoot自带 apache tomcat 主要技术: Java,Springboot,mybatis,mysql,vue 2.视频演示地址 3.功能 系统中…

@controller注解和@RestController注解详解

文章目录 控制器MVC控制器REST 控制器 controllerRestController总结 控制器 MVC控制器 在了解这两种注解之前我们需要先知道控制器的概念&#xff0c;我们项目中常见的就是MVC控制器&#xff0c;MVC 是一种软件架构模式&#xff0c;它将应用程序分为三个主要组件&#xff1a;…

R语言统计分析——气泡图

参考资料&#xff1a;R语言实战【第2版】 气泡图&#xff08;bubble plot&#xff09;用来展示三个定量变量间的关系&#xff1a;先创建一个二维散点图&#xff0c;然后用点的大小来代表第三个边变量的值。 我们可以使用symbols()函数来创建气泡图。该函数可以在指定的(x,y)坐标…

如何鉴定一段抗体序列的CDR区(CDR1、CDR2、CDR3)

愿武艺晴小朋友一定得每天都开心 如果有一批的抗体序列,可按下面的步骤来处理&#xff1a; (1)可以先处理为fasta的格式&#xff08;或者不处理手动粘贴&#xff09; >20B11 NIVLTQSPASLAVSLGQRATISCKASQSVDYDGDSYMNWYQQKPGQPPKLLIYAASNLESGIPARFSGSGSGTDFTLNIHPVEEEDAA…

华为启动鸿蒙原生应用开发者激励计划 12月31日前上架最高可获10万元

华为开发者官网今天发布了《鸿蒙原生应用开发者激励计划》的公告。此计划是华为给鸿蒙原生应用的开发者提供的现金及流量扶持的专属激励资源&#xff0c;鼓励开发者积极投入鸿蒙原生应用开发&#xff0c;加速应用上架&#xff0c;共创鸿蒙生态。 开发者需要在本计划要求的报名周…

深度学习:手写感知机

文章目录 前言感知机模型训练模型预测小结 前言 上面是一只猫&#xff0c;人类的大脑可以很轻松地识别出。人脑是如何识别的呢&#xff1f; 人类能够识别出这只猫&#xff0c;是因为这张图片具有猫的典型特征。例如&#xff0c;猫的耳朵、眼睛、猫须、嘴巴等独特的形态特征&am…

gcc学习

理论 在使用 GCC (GNU Compiler Collection) 进行 C 或 C 程序的编译时&#xff0c;可以将整个过程分为四个主要阶段&#xff1a;预处理、编译、汇编和链接。下面是每个阶段的命令示例&#xff1a; 1. 预处理-E 预处理阶段会处理所有的预处理指令&#xff08;如 #include 和…

ArcGis JS天地图 暗色地图

方法一&#xff1a;使用css filter 在body下增加svg&#xff0c;并增加需要用到的滤镜&#xff0c;这边用到x-rays <svg id"svgfilters" aria-hidden"true" style"position: absolute; width: 0; height: 0; overflow: hidden"version"…