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

【数据结构】最小生成树(Prim算法,普里姆算法,普利姆)、最短路径(Dijkstra算法,迪杰斯特拉算法,单源最短路径)

文章目录

    • 前置问题
      • 问题解答
    • 一、基础概念:最小生成树的定义和性质
      • (1)最小生成树(Minimal Spanning Tree)的定义
      • (2)最小生成树(MST)的性质
    • 二、如何利用MST性质寻找最小生成树
    • 三、Prim算法
      • (1)Prim算法思想
      • (2)Prim算法形成最小生成树的详细过程
      • (3)Prim算法的C++和python实现
    • 四、Dijkstra算法
      • (1)和Prim算法的联系
      • (2)Dijkstra算法思想

前置问题

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

问题解答

在这里插入图片描述

一、基础概念:最小生成树的定义和性质

(1)最小生成树(Minimal Spanning Tree)的定义

  • 生成树的代价:设G(V,E)G(V,E)G(V,E)是一个无向连通网图,生成树上各边的权值之和称为生成树的代价
  • 最小生成树:在图GGG所有生成树中,代价最小的生成树最小生成树

(2)最小生成树(MST)的性质

假设G=(V,E)G=(V,E)G=(V,E)是一个无向连通网图,UUU是顶点集的一个非空子集。若(u,v)(u,v)(u,v)是一条具有最小权值的边,其中u∈U,v∈V−Uu\in U,v\in V-UuU,vVU,则必存在一棵包含边u,vu,vu,v的最小生成树。

在这里插入图片描述

二、如何利用MST性质寻找最小生成树

  • 找到两个点集之间最小权值的边(u,v)(u,v)(u,v),让具有最小权值的(u,v)(u,v)(u,v)成为最小生成树的一部分,将大于最小权值的(u,v)(u,v)(u,v)删除。

接下来有两个思路:

  • 从一个点出发,一次加入点形成点集(Prim算法)
  • 从边出发,将点集合并,避免形成环(Kruskal算法)

三、Prim算法

(1)Prim算法思想

对点做操作,维护一个在最小生成树中的点的顶点集A,以及一个待处理点的顶点集B,每次找出连接这两个集合的最短边,并将其两个顶点都加入集合A,直到所有顶点都处理完毕。

抽象描述:(觉得抽象跳过)

在这里插入图片描述

(2)Prim算法形成最小生成树的详细过程

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

  • 红色线段表示最小生成树
  • 蓝圈表示集合UUU,其他顶点集合为V−UV-UVU
  • 蓝色线段表示UUUV−UV-UVU的相邻边

在这里插入图片描述

计算U中每个点和其相邻点之间的代价,找出代价最小的点V5,将V5纳入U集合。计算U中每个点和其相邻点之间的代价,找出代价最小的点V5,将V5纳入U集合。计算U中每个点和其相邻点之间的代价,找出代价最小的点V5,将V5纳入U集合。

在这里插入图片描述


















在这里插入图片描述


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


在这里插入图片描述


在这里插入图片描述

(3)Prim算法的C++和python实现

四、Dijkstra算法

(1)和Prim算法的联系

Dijkstra算法和Prim算法都是最短路径算法,主要用于求图的最短路径

不同点在于,Dijkstra算法适用于有向图起点到其他点的最短路径,而Prim算法适用于无向图求最小生成树。它们的求解过程也略有不同。Dijkstra算法每次选择距离起点最近的点作为新的访问点,更新其他点到起点的最短距离,直到所有点都被访问。Prim算法则从一个起点开始,不断选择与已经访问过的点相连且边权最小的点,直到图上所有点都被访问。

(2)Dijkstra算法思想

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

算出A点到图中每一点的路径长度,选出一条最短路径:A->B,将顶点B加入集合S。

增加了一条最短路径之后,顶点A到其他点的路径是不是有更短的路径了呢?

更新最短路径:
在这里插入图片描述


A->C,A->D,A->E中选出最短路径:A->D,并将D顶点加入S集合。更新所有最短路径。
在这里插入图片描述


在这里插入图片描述


在这里插入图片描述

http://www.lryc.cn/news/3279.html

相关文章:

  • Session与Cookie的区别(一)
  • 【Java】重载和重写的区别
  • AcWing 第 90 场周赛
  • 刚刚,体验了一把Bing chat很爽
  • 牛客网Python篇数据分析习题(二)
  • 如何用Python打包好exe文件,并替换图标
  • NFC概述摘要
  • Python-项目实战--贪吃蛇小游戏(1)
  • vscode sftp从linux服务器下载文件至本地:No such file or dictionary【已解决】
  • 详解指针(2)(初阶版)
  • 超详细讲解字符串查找函数(保姆级教程!!!)
  • LeetCode-1138. 字母板上的路径【哈希表,字符串】
  • Vue 可配置化的路由缓存(Vu2 Vue3)
  • Linux VPU驱动
  • spring 笔记
  • Java日志框架学习
  • 基础面试题:堆和栈的区别
  • (干货教程)在VSCode并使用chatgtp插件编写CC++语言程序
  • 【思维模型】概率思维的价值:找到你的人生算法,实现阶级跃迁!
  • SpringBoot + kotlin/java + Mybatis-Plus +Sqlite + Gradle多模块项目
  • Docker 容器与容器云读书笔记(一)
  • 软件设计(九)
  • FoveaBox原理与代码解析
  • Linux内核启动(1,0.11版本)启动BIOS与加载内核
  • python制作贪吃蛇小游戏,畅玩无限制
  • MySQL-InnoDB数据页结构浅析
  • Java、JSP职工人事管理系统设计与实现
  • 数据结构与算法这么难,为什么我们还要学习?
  • 剑指 Offer 52. 两个链表的第一个公共节点
  • 可以写进简历的软件测试电商项目,不进来get一下?