第六章 图 七、最短路径(BFS算法、Dijkstra算法、Floyd算法)

news2025/1/19 3:35:10

目录

一、BFS算法(单源最短路径)

(1)介绍:

(2)例子:

二、Dijkstra算法(单源最短路径)

(1)介绍:

(2)例子:

第一步

第二步

第三步

第四步

最后

三、Floyd算法(各个顶点间的最短路径)

代码:

例子:

第一步

第二步

第三步

第四步

结论:

注意★★★★★:


一、BFS算法(单源最短路径)

(1)介绍:

这个算法是计算所有路径权值为1的图的最短路径。

(2)例子:

从结点2出发,使用宽度优先遍历,获得最小生成树,树的层数也就是到达该结点的最短路径。

二、Dijkstra算法(单源最短路径)

(1)介绍:

 找到有向有权图的最短路径。

(2)例子:

从V0出发找到最短路径

第一步

我们需要创建3个数组,分别存储

该结点是否已找到最短路径

最短路径的长度

路径上的前驱

第二步

找最短的路径长度,并移动到该结点

从该V4结点我们可以找到通往V4的路径长度为5(前驱为V0),

通往V1的新路径长度为3+5=8(前驱为V4),

还有V2的路径5+9=14(前驱为V4),V3的路径5+2=7(前驱为V4),更新数组。

第三步

遍历该结点是否已找到最短路径的数组,找到它们路径的长度最短的结点。

在上图中,最短结点为V3,于是,我们将移动到V3,并将V3设置为已找到最短路径。

我们找到了前往V0的新路径,但是V0已经找到了最短路径。所以跳过。

还找到了前往V2的新路径,路径长度为7+6=13,用它与14比较,发现小于14,所以更新数组。

第四步

遍历该结点是否已找到最短路径的数组,找到它们路径的长度最短的结点。

在上图中,最短结点为V1,于是,我们将移动到V1,并将V1设置为已找到最短路径。

我们找到了前往V2的新路径,路径长度为8+1=9,前驱为V1。

更新数组,发现V2已经是最后一个结点,直接设置为true。

最后

我们可以通过这个数组任意结点找到到达V0的最短路径。

例如V2,L=9,v2 <- v1 <- v4 <- v0

时间复杂度:O(V^2)

注意:Dijkstra算法不适用于有负权值的带权图。

三、Floyd算法(各个顶点间的最短路径)

代码:

时间复杂度,O(V^3)

空间复杂度,O(V^2)
 

例子:

第一步

根据所给的图,不允许中转,做出相应的距离矩阵。

第二步

(1)加入V0,使路径允许在V0进行中转。

(2)我们发现,加入V0后,V2有新的路径指向V1,长度为5+6=11,与原来的进行比较,11<∞,于是更新矩阵A[V2][V1]的值为11,path[V2][V1]为0(V0为中转点)

(3)V1有新的路径指向V2,但是10+13>4,所以不更新。

第三步

(1)加入V1,使路径允许在V0,V1进行中转。

(2)我们发现,加入V1后,V0有新的路径指向V2,长度为4+6=10,与原来的进行比较,10<13,于是更新矩阵A[V0][V2]的值为10,path[V0][V2]为1(V1为中转点)

第四步

(1)加入V2,使路径允许在V0,V1,V2进行中转。

(2)我们发现,加入V2后,V1有新的路径指向V0,长度为4+5=9,与原来的进行比较,9<10,于是更新矩阵A[V1][V0]的值为9,path[V1][V0]为2(V2为中转点)

结论:

注意★★★★★:

Floyd算法可以用于负权值带权图;

Floyd算法不能解决带有“负权回路"的图(有负权值的边组成回路),这种图有可能没有最短路径;

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

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

相关文章

obsstudio下载使用

官网 Open Broadcaster Software | OBS 介绍 OBS是Open Broadcaster Software的简称&#xff0c;是一款开源&#xff0c;用于视频录制以及直播串流的软件&#xff0c;它支持Windows、Mac以及Linux操作系统。OBS使用容易、操作简单&#xff0c;对于新手小白来说非常友好。如果…

集卡拖车运输最新政策调整来了_箱讯科技

国庆佳节马上就要到了&#xff0c;我们即将迎来一个重要的假期。 然而&#xff0c;对于许多进出口企业来说&#xff0c;国庆节并不仅仅意味着放松和庆祝&#xff0c;还需要提前做好出运准备。准时出运对于维护客户信任和业务运营至关重要。 伴随着国庆节的临近&#xff0c;运…

2000-2021年上市公司全要素生产率数据(LP法)(含原始数据、计算代码、计算结果)

2000-2021年上市公司全要素生产率数据&#xff08;LP法&#xff09;&#xff08;含原始数据、计算代码、计算结果&#xff09; 1、时间&#xff1a;2000-2021年 2、指标&#xff1a;股票代码、年份、证券代码、固定资产净额、营业总收入、营业收入、营业成本、销售费用、管理…

论文阅读之Learning and Generalization of Motor Skills by Learning from Demonstration

0、论文基本信息 DMP经典论文 论文题目&#xff1a;Learning and Generalization of Motor Skills by Learning from Demonstration 会议名称&#xff1a;2009 ICRA 论文作者&#xff1a;Peter Pastor, Heiko Hoffmann, Tamin Asfour and Stefan Schaal 作者简介&#xff1a;…

如何导出数据库数据字典

1、随便找一个工程项目&#xff0c;在项目build.gradle配置文件添加以下依赖 compile group: cn.smallbun.screw, name: screw-core, version: 1.0.52、刷新下载依赖 3、将以下代码拷贝到工程任意Java目录 ScrewDemo.java package com.xxx;import cn.smallbun.screw.core.C…

Manim 中文显示问题报错解决办法

使用Manim直接制作这种动画视频的话是不支持中文的,需要进行一些修改,效果如图所示。 但是修改的方案都太坑,经过自己不断的研究找到了一个比较简单实用的方法。 文章目录 源文件修改代码修改源文件修改 实用everuthing找到ctex_template.tex文件。 我这里的路径是D:\MyT…

定时器+BOM

9.定时器BOM 1.定时器 **概念:**重复执行一个函数 1.1setInterval() setInterval(“代码/函数”,时间,参数),返回定时器的序列号,默认从1开始 clearInterval(序列号)清除定时 <button class"start">开启定时器</button><button class"close…

Elasticsearch:为具有许多 and/or 高频术语的 top-k 查询带来加速

作者&#xff1a;Adrien Grand Disjunctive queries&#xff08;term_1 OR term_2 OR ... OR term_n&#xff09;非常常用&#xff0c;因此在提高查询评估效率方面它们受到了广泛关注。 Apache Lucene 对于评估 disjunctive queries 有两个主要优化&#xff1a;一方面用于详尽评…

Mac os 安装homebrew

Mac os 不会自带homebrew工具&#xff0c;而很多需要的工具需要用brew命令下载和安装&#xff0c;但是因为homebrew是国外网站&#xff0c;如果没有VPN&#xff0c;就无法下载。下面记录一下如何解决这个问题。 1、国内安装的命令如下&#xff1a; /bin/zsh -c "$(curl …

[管理与领导-89]:IT基层管理者 - 扩展技能 - 5 - 职场丛林法则 -3- 在丛林(公司->团队->个人)中定位自己

目录 前言&#xff1a; 一、了解公司市场 1.1 了解公司的途径 1.2 了解一个公司的哪些方面 1.3 商业的本质 1.4 公司的本质 1.5 公司的残酷性 1.6 公司与丛林的相似性 1.7 公司在市场中的定位涉及以下几个方面&#xff1a; 1.8 等价交换与剩余价值 在职场中的体现 二…

input输入事件

我要实现input输入框一边输入&#xff0c;一边在控制台输出结果 现有如下代码 <body><input type"text" onchange"myFunction()" /><script>function myFunction(){console.log(999)}</script> </body> 当敲下回车键后才会…

用python爬豆瓣电影《热烈》短评

一、爬虫对象-豆瓣电影短评 今天分享一期爬虫案例&#xff0c;爬取的目标是&#xff1a;豆瓣上任意一部电影的短评&#xff08;注意&#xff1a;是短评&#xff0c;不是影评&#xff01;&#xff09;&#xff0c;以《热烈》这部电影为例&#xff1a; ▲ 爬取目标 爬取以上6个…

阿里云-源码构建容器镜像

1、阿里云Code代码平台 1.1 创建访问令牌。 登录云效Codeup控制台&#xff0c;单击右上角个人设置。 在个人设置页面&#xff0c;单击左侧导航栏中的个人访问令牌。 单击创建访问令牌&#xff0c;设置配置项&#xff0c;然后单击立即创建。以下为创建访问令牌需要授予的最小权…

【C语言】【strcpy的使用和模拟实现】

1.strcpy的使用&#xff1a; char* strcpy(char* destination,const char* source)返回类型是字符指针&#xff0c;参数是接受方字符串的首地址和要拷贝的字符串的首地址 从接受地的‘\0’开始拷贝&#xff0c;会将源字符串中的’\0’也拷贝过来目标空间必须足够大&#xff0…

PASCAL VOC2012数据集以及制作自己的数据集

目录 VOC2012目录结构制作自己的数据集标注图片软件使用流程软件使用 VOC2012目录结构 制作自己的数据集 标注图片软件 github开源项目&#xff0c;形成的是xml文件格式 使用流程 软件使用

docker四种网络模式

文章目录 一.为什么要了解docker网络二.docker 网络理论三.docker的四类网络模式3.1 bridge模式3.2 host模式3.3 container模式3.4 none模式 四.bridge模式下容器的通信4.1 防火墙开启状态4.2 防火墙关闭状态 一.为什么要了解docker网络 当你开始大规模使用Docker时&#xff0…

简单讲讲在一台机器上用docker部署hadoop HDFS

为什么写这篇文章? 老东西叫我用vmvare部署hadoop,我觉得这简直蠢毙了,让我们用docker和docker-compose来快速的过一遍如何使用docker-compose来部署简单的hadoop集群范例 写在前面,一定要看我!!! 还有注意&#xff01;Hadoop中的主机名不能带-或者_ 注意了!一定注意存储空…

uboot 顶层Makefile-make xxx_deconfig过程说明三

一. uboot 的 make xxx_deconfig配置 本文接上一篇文章的内容。地址如下&#xff1a;uboot 顶层Makefile-make xxx_deconfig过程说明二_凌肖战的博客-CSDN博客 本文继续来学习 uboot 源码在执行 make xxx_deconfig 这个配置过程中&#xff0c;顶层 Makefile有关的执行思路。 …

SpringBoot临时属性简单说明

1.修改工程的端口 说明&#xff1a;将工程的端口修改成8080端口 java -jar .\springboot_09_ssmp-0.0.1-SNAPSHOT.jar --server.port8080 修改前 修改后 2.修改连接数据库密码 说明&#xff1a;修改的是application.yml中password的值 java -jar .\springboot_09_ssmp-0.0…

就业这么难,十个软件测试项目帮你简历优化!

简历中项目经验太苍白&#xff0c;面试官一眼假&#xff0c;没有面试邀约&#xff0c;倒在海投第一步&#xff0c;看看这十个项目&#xff0c;总有一个你需要的&#xff01; 1.selenium定位web元素(12306抢票实战项目) 项目测试目的 学会Selenium定位web元素的方法熟练浏览器…