文章目录

  • 前置问题
    • 问题解答
  • 一、基础概念:最小生成树的定义和性质
    • (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)是一个无向连通网图,生成树上各边的权值之和称为生成树的代价
  • 最小生成树:在图 G G G所有生成树中,代价最小的生成树最小生成树

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

假设 G = ( V , E ) G=(V,E) G=(V,E)是一个无向连通网图, U U U是顶点集的一个非空子集。若 ( u , v ) (u,v) (u,v)是一条具有最小权值的边,其中 u ∈ U , v ∈ V − U u\in U,v\in V-U u∈U,v∈V−U,则必存在一棵包含边 u , v u,v u,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算法形成最小生成树的详细过程


图注:

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

计算 U 中每个点和其相邻点之间的代价,找出代价最小的点 V 5 ,将 V 5 纳入 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集合。更新所有最短路径。



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

  1. 单源最短路径-Dijkstra(迪杰斯特拉算法)

    迪杰斯特拉算法时间复杂度为O(n^2),其中n为顶点个数. 该算法用于求单源最短路径.并且图中的边不允许带负权值. #include <iostream> using namespace ...

  2. 图的应用---最短路径问题 用迪杰斯特拉算法解决 《地铁换乘问题》

    图的应用-最短路径问题 用迪杰斯特拉算法解决 <地铁换乘问题> 代码是在我学习的过程中完成的,也许会有问题,希望大家批评指正. 题目: 描述:已知2条地铁线路,其中A为环线,B为东西向线路 ...

  3. python写算法求最短路径,Python实现迪杰斯特拉算法并生成最短路径的示例代码

    def Dijkstra(network,s,d):#迪杰斯特拉算法算s-d的最短路径,并返回该路径和代价 print("Start Dijstra Path--") path=[ ...

  4. 图的最短路径之(迪杰斯特拉算法)python实现

    前面我们已经了解到了无环有向图怎样求关键路径的方法,今天我们来看看无向图怎样求最短路径,这在实际应用过程中的作用很大,不如交通路线图,从出发点到终点,走哪条路用时最短,或者花费最少等问题. 我们先来看 ...

  5. Dijkstra Algorithm (迪杰斯特拉算法)

    这里需要详细说明参数,v表示第一个顶点,dist[i]表示从v到各个顶点vi的最短路径长度,path[]保存的是最短路径上一个顶点的位置,它其实就像一棵树,保存的是双亲节点的,遍历的时候可以按照双亲节 ...

  6. hdu3790最短路径问题(迪杰斯特拉算法+详解+代码)

    最短路径问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...

  7. 最短路径之Dijkstra(迪杰斯特拉)算法(无向图)

    简介      Dijkstra(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止.由for循环可知,其时间 ...

  8. 算法与数据结构(六) 迪杰斯特拉算法的最短路径(Swift版)

    上篇博客我们详细的介绍了两种经典的最小生成树的算法,本篇博客我们就来详细的讲一下最短路径的经典算法----迪杰斯特拉算法.首先我们先聊一下什么是最短路径,这个还是比较好理解的.比如我要从北京到济南,而 ...

  9. 校园导游系统_C语言实现_Dijkstra(迪杰斯特拉算法)_数据结构

    西京学院导游系统 摘要   要完成对整个导游图系统的功能实现,需要对每一项功能都有清楚的设想和认识,了解并明确每一项功能的实现和需要解决的问题,选择正确并且高效的算法把问题逐个解决,最终实现程序的正确 ...

  10. 图论应用 floyd(弗洛伊德)算法、dijkstra(迪杰斯特拉)算法

    前言 图论应用是非常广泛的,不同于二叉树,二叉树是应用在数据存储结构提高查询效率的,而图论则是用在辅助决策系统中,求得最优化解的等等,而本篇文章中介绍的floyd(弗洛伊德)算法.dijkstra(迪 ...

最新文章

  1. 70、80后、90后,小时候开学的场景!你还记得吗?
  2. python的image读取的图片是什么类型的-python如何实现读取并显示图片(不需要图形界面)...
  3. 如何才能学好python编程零基础_Python脚本该怎么学,零基础也可以学好Python编程吗?...
  4. 2007上半年網絡工程師考題
  5. mysql数据库密码错误_MySQL数据库经典错误六 数据库密码忘记的问题
  6. nbiot开发需要掌握什么_学习软件开发需要准备什么?
  7. maven报错:Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:x.x.x:test
  8. ylbtech-dbs-m-YinTai(银泰网)
  9. Java中Session详解
  10. Redis实战pdf
  11. urp教务系统php,URP高校教务管理系统
  12. php7isapi,如何选择PHP套件中ISAPI和FastCGI模式的版本?_护卫神
  13. 喜马拉雅FM下载的音频转换为正常文件的JAVA实现
  14. try固定搭配_regret cease try等词的固定搭配用法
  15. 计算机优化和维护的主要内容,计算机组装与维护(全)
  16. ADO的七个对象详情解读
  17. 【bzoj3772】 精神污染 dfs序+主席树
  18. 想起某个人,想到某些事
  19. 收藏的博客 -- Qt有关的GitHub/Gitee开源项目
  20. 【机器学习】PCA主成分项目实战:MNIST手写数据集分类

热门文章

  1. 游戏编程模式 - 观察者模式
  2. Git创建分支和查看分支命令
  3. 【仿真设计】仿真技术在智能制造中的作用;智能制造难点在模型,焦点在仿真;汽车行业CAE研究
  4. Unity 径向模糊 简易解决方案
  5. Bose SoundLink Revolve或者Bose SoundLink Revolve+ AUX音频播放一会没有声音
  6. 加油------加油
  7. 2017年第26届上海国际连锁加盟展览会会刊(参展商名录)
  8. 超级光棍节,你想好怎么过了吗?来聆听大师的演讲吧
  9. Chapter 4 Part 5 WPAS扫描源码走读
  10. 【Java代码】MP3、flac歌曲批量生成同名的“xxx.lrc”歌词文件导入索尼黑砖二代