6.4.2_3最短路径问题_Floyd算法
Floyd弗洛伊德
膜拜大佬,给大佬鞠躬鞠躬鞠躬。。。。。。。。。
Floyd算法 ----解决顶点间的最短路径:
过程:
如下:
初始化(没有中转点):2个邻接矩阵A和path,第一个是没有中转点的2个顶点之间的最短路径(注意是2个顶点之间的直接路径,中间没有经过其他顶点,如果2个顶点比如A->B没有直接路径,A->C->B有路径,此时也写∞),第2个是目前能找到的最短路径中2个顶点之间的中转点,刚开始没有中转点所以各2个顶点之间的中转点都设为-1
中转点加入V0顶点:在没有加入V0中转点时,A[2][1]即V2->V1路径长度根据A邻接矩阵知是∞,加入V0后即K=0,可以V2->V0,V0->V1,即A[2][0]+A[0][1]=5+6=11(根据A第一个邻接矩阵得出)得出加了中转点后V2->V1最短路径由∞变为11,则修改A[2][1]即第一个邻接矩阵V2->V1最短路径为11,修改第二个邻接矩阵V2->V1中转点为0,所有的顶点都需要加入以上判断,然后修改A和Path,目前看只有V2、V1顶点需要(A(0)[2][1]=11即加入了0号中转点的V2->V1的最短路径长度为11,path(0)[2][1]=0,即当前的V2->V1最短路径长度加入了0号中转点,每次都要判断未加入中转点的最小路径长度>加入了中转点之后的最小路径长度,只有满足这个式子才会修改A和Path)
中转点加入V1顶点:在没有加入V1中转点时,V0->V2路径长度是13,加入后V0->V1->V2即6+4=10,加入后值小满足规则条件A(0)[0][2]>A[0][0][1]+A(1)[1][2],修改A(1)[0][2]=10,path(1)[0][2]=1,其他顶点无需更改,加入中转点后路径没有变化
中转点加入V2顶点:在没有加入V2中转点时,V1->V0路径长度是10,加入后V1->V2->V0即4+5=9,加入后值小满足规则条件A(1)[1][2]>A(1)[1][2]+A(1)[2][0],修改A(2)[1][0]=9,path(2)[1][0]=2
path写的是中转点,把谁加入了中转点对应的path路径上的值就写谁,A写的是最短路径长度
经过n(顶点个数)轮中转之后得到A(n-1)path(n-1)
如下:由A(n-1)即A(2)得,V1->V2最短路径是4,由path(2)得V1->V2是-1,即V1->V2最短路径4没有经过中转点,即为V1->V2,V0->V2最短路径是10,由path(2)得V1->V2是1,即V0->V2最短路径10经过中转点1,即为V0->V1->V2即V0_V1_V2
代码如下:
准备一个图的邻接矩阵A+path矩阵初始值都设为-1,开始每循环一次增加一个中转点,每增加一个中转点遍历一次A邻接矩阵(遍历行和列),看加了中转点之后的路径长度和不加谁小,如果加了小更新邻接矩阵A最短路径长度和path中转点
时间复杂度:要根据顶点个数遍历3次即O(|V³|)
空间复杂度:矩阵的存储空间行和列即O(|V²|)
5个顶点例子:
中转点V0:没有需要更新的
中转点V1:既然是V1作为中间点出现,那必然要找指向V1的点作为起点V2和从V1指出的点(此时不要直接看图,要看邻接矩阵)V3、V4,可得V1作为中间点、V2作为起点有2条路径,V2->V1->V3=1+1=2,但是V2->V3没有直接路径即∞,修改A(1)[2][3]=2,path(1)[2][3]=1,另一条V2->V1->V4=1+5=6,V2直接到V4=7,则修改A(1)[2][4]=6,path(1)[2][4]=1【修改对应path上的横纵坐标确定的值为1】
中转点V2:既然是V2作为中间点出现,那必然要找指向V2的点作为起点V0和从V2指出的点(直接看邻接矩A中V2作为横坐标V2所在行有值的点,不要看图!!!)即V1、V3(V2->V3在图中并没有直接指向,但是在邻接矩阵A中(2,3)=2,是因为上一步已经加入了中转点V1,V2->V3没有直接路径,但是可以V2->V1->V3=2有中转点路径,即在使用中转点V2时也使用了中转点V1的结果,在已经有了一个中转点的情况下,计算某2个顶点最短路径时也要看邻接矩阵而不是看图上边的权值!!!)、V4,可得V2作为中间点、V0作为起点有3条路径,V0->V2->V1=1+1=2(邻接矩阵中V0->V2是1,V2->V1是1) <V0->V1是∞,修改A(2)[0][1]=2,path(2)[0][1]=2,另一条V0->V2->V4=1+6=8(注意不要看图上的权值,看邻接矩阵中的最短路径!!!否则就变成了1+7=8,邻接矩阵A上V0->V2=1,V2->V4=6即1+6=7),V0直接到V4=10,则修改A(2)[0][4]=8,path(2)[0][4]=2,另一条V0->V2->V3=1+2=3(邻接矩阵A上V0->V2=1,V2->V3=2即1+2=3) < V0->V3=∞,则修改A(2)[0][3]=3,path(2)[0][3]=2【修改对应path上的横纵坐标确定的值为2】
中转点V3:上同
中转点V4:上同
根据最终中转矩阵找路径:
如下为最终中转的A和path,找V0->V4路径,由A知V0->V4最短路径为4,由path知V0->V4中转点是3,再由A知V3->V4最短路径1,由path知V3->V4=-1即V3和V4之间没有中转点,再看V0->V3,由A知V0->V3最短路径3,由path知V0->V3=2级V0->V3中转点V2,即V0->V2->V3,看V0->V2,由A知V0->V2最短路径1,由path知V0->V2=-1即V0->V2没有中转点,再看V2->V3,由A知V2->V3最短路径2,由path知V2->V3=1即V2->V3有中转点V1,即V2->V1->V3,看V2->V1,由A知V2->V1最短路径1,由path知V2->V1=-1即V2->V1没有中转点,再看V1->V3,由A知V1->V3最短路径1,由path知V1->V3=-1即V1->V3没有中转点
V0->V3->V4 第一轮 V3->V4不动路径为1,看V0->V3有哪些中转点
V0->V2->V3->V4第二轮 V0->V2不动路径1、V3->V4不动路径1,看V2->V3有哪些中转点
V0->V2->V1->V3->V4第三轮 V0->V2、V2->V1、V1->V3、V3->V4不动路径1,各路径无中转点
练习:
弗洛伊德算法可解决带负权值,但不能解决带回路的负权值
知识回顾:
下次再见
相关文章:

6.4.2_3最短路径问题_Floyd算法
Floyd弗洛伊德 膜拜大佬,给大佬鞠躬鞠躬鞠躬。。。。。。。。。 Floyd算法 ----解决顶点间的最短路径: 过程: 如下: 初始化(没有中转点):2个邻接矩阵A和path,第一个是没有中转点的2个顶点之间的最短路径…...

<PLC><socket><西门子>基于西门子S7-1200PLC,实现手机与PLC通讯(通过websocket转接)
前言 本系列是关于PLC相关的博文,包括PLC编程、PLC与上位机通讯、PLC与下位驱动、仪器仪表等通讯、PLC指令解析等相关内容。 PLC品牌包括但不限于西门子、三菱等国外品牌,汇川、信捷等国内品牌。 除了PLC为主要内容外,PLC相关元器件如触摸屏(HMI)、交换机等工控产品,如…...
day 33 python打卡
作业:今日的代码,要做到能够手敲。这已经是最简单最基础的版本了。 import torch print(torch.__version__) print(torch.version.cuda) print(torch.cuda.is_available()) import torch# 检查CUDA是否可用 if torch.cuda.is_available():print("CU…...
开发时如何通过Service暴露应用?ClusterIP、NodePort和LoadBalancer类型的使用场景分别是什么?
一、Service核心概念 Service通过标签选择器(Label Selector)关联Pod,为动态变化的Pod集合提供稳定的虚拟IP和DNS名称,主要解决: 服务发现负载均衡流量路由 二、Service类型详解 1. ClusterIP(默认类型…...
【机械视觉】Halcon—【六、交集并集差集和仿射变换】
【机械视觉】Halcon—【六、交集并集差集和仿射变换】 目录 【机械视觉】Halcon—【六、交集并集差集和仿射变换】 介绍 交集并集差集介绍: 1. 交集(Intersection) 2. 并集(Union) 3. 差集(Differenceÿ…...

深度学习核心网络架构详解(续):从 Transformers 到生成模型
在上一篇文章中,我们详细介绍了卷积神经网络 (CNN)、循环神经网络 (RNN) 及其变体 LSTM 和 GRU。本文将继续探讨其他必须掌握的深度学习网络架构,包括 Transformers、生成对抗网络 (GAN)、自编码器 (Autoencoder) 以及强化学习基础。我们将深入讲解这些技…...

AI智能混剪视频大模型开发方案:从文字到视频的自动化生成·优雅草卓伊凡
AI智能混剪视频大模型开发方案:从文字到视频的自动化生成优雅草卓伊凡 引言:AI视频创作的未来已来 近年来,随着多模态大模型(如Stable Diffusion、Sora、GPT-4)的爆发式发展,AI已经能够实现从文字生成图像…...

allWebPlugin中间件VLC专用版之截图功能介绍
背景 VLC控件原有接口具有视频截图方法,即video对象的takeSnapshot方法,但是该方法返回的是一个IPicture对象,不适合在谷歌等现代浏览器上使用。因此,本人增加一个新的视频截图方法takeSnapshot2B64方法,直接将视频截图…...
【JavaSE】异常处理学习笔记
异常处理 -异常介绍 基本概念 Java语言中,将程序执行中发生的不正常情况称为“异常”。(开发过程中的语法错误和逻辑错误不是异常) 执行过程中所发生的异常事件可分为两类 Error(错误):Java虚拟机无法解决…...

Scratch节日 | 六一儿童节
六一儿童节到啦!快来体验这款超简单又超好玩的 六一儿童节 小游戏吧!只需要一只鼠标,就能尽情释放你的创意,绘出属于你自己的缤纷世界! 🎮 玩法介绍 鼠标滑动:在屏幕上随意滑动鼠标,…...

深度解析:跨学科论文 +“概念迁移表” 模板写作全流程
跨学科论文速通!融合“概念迁移表”的写作导航模板 你的论文是否曾被导师皱眉评价为“四不像”?不同学科的术语在稿纸上打架,核心逻辑若隐若现? 别让心血沦为学术混搭的牺牲品。一张精心设计的 概念迁移表,能将两个看…...

深度剖析Node.js的原理及事件方式
早些年就接触过Node.js,当时对于这个连接前后端框架就感到很特别。尤其是以独特的异步阻塞特性,重塑了了服务器端编程的范式。后来陆陆续续做了不少项目,通过实践对它或多或少增强了不少理解。今天,我试着将从将从原理层剖析其运行…...

VScode-使用技巧-持续更新
一、Visual Studio Code - MACOS版本 复制当前行 shiftoption方向键⬇️ 同时复制多行 shiftoption 批量替换换行 在查找和替换面板中,你会看到一个 .∗ 图标(表示启用正则表达式)。确保这个选项被选中,因为我们需要使用正则…...

主流 AI IDE 之一的 Windsurf 使用入门
一、Windsurf 的常见入门界面 以上是本次展示Windsurf版本信息。 1.1 个人配置中心 1.2 AI 助手快捷设置 1.3 使用额度查看页面 1.4 智能助手 Windsurf 编辑器中 AI 助手名称 :Cascade 。打开 Cascade 窗口,开始聊天就可以了。方框里有写和聊两种状态锁…...

大数据量下的数据修复与回写Spark on Hive 的大数据量主键冲突排查:COUNT(DISTINCT) 的陷阱
背景与问题概述 这一周(2025-05-26-2026-05-30)我在搞数据拟合修复优化的任务,有大量的数据需要进行数据处理及回写,大概一个表一天一分区有五六千万数据,大约一百多列的字段。 具体是这样的我先取档案&#x…...
Cursor 对话技巧 - 前端开发专版
引言 本文档旨在为前端开发团队提供与 Cursor AI 助手高效对话的技巧和方法,帮助团队成员更好地利用 AI 工具提升开发效率。文档中的技巧源自项目中的提示词相关文件,并经过整理和优化,专注于前端开发的各个场景。 目录 Cursor 对话技巧团队…...

历年南京理工大学计算机保研上机真题
2025南京理工大学计算机保研上机真题 2024南京理工大学计算机保研上机真题 2023南京理工大学计算机保研上机真题 在线测评链接:https://pgcode.cn/school 求阶乘 题目描述 给出一个数 n n n ( 1 ≤ n ≤ 13 ) (1 \leq n \leq 13) (1≤n≤13),求出它…...

Web前端常用面试题,九年程序人生 工作总结,Web开发必看
前端编程,JavaScript 从无知到觉醒 做 Web 开发,离不开 HTML,CSS,JavaScript,尽管日常工作以后台开发为主,但接触的多了,慢慢地理解深入,从只会使用 JS 写函数,发展到使用…...
HTML实战项目:高考加油和中考加油
设计思路 页面加载后会自动显示高考内容,点击顶部按钮可以切换到中考内容。倒计时会每秒更新,为考生提供实时的备考时间参考。 使用代表希望的蓝色和金色渐变作为主色调 顶部导航栏可切换高考/中考内容 添加动态倒计时功能 设计励志名言卡片和备考小贴…...

Rk3568驱动开发_设备树点亮LED_11
代码: #include <linux/module.h> #include <linux/kernel.h> #include <linux/init.h> #include <linux/fs.h> #include <linux/slab.h> #include <linux/uaccess.h> #include <linux/io.h> #include <linux/cdev.h…...

多功能文档处理工具推荐
软件介绍 今天为大家介绍一款功能强大的文档编辑工具坤Tools,这是一款在吾爱论坛广受好评的办公软件。 软件背景 坤Tools是由吾爱论坛用户分享的软件,在论坛软件榜单上长期位居前列,获得了用户的一致好评。 软件性质 这是一款完全离线、…...
如何科学测量系统的最高QPS?
要准确测量系统的最高QPS(Queries Per Second),既不能简单依赖固定请求数(如2万次),也不能盲目压到服务器崩溃。以下是专业的方法论和步骤: 1. 核心原则 目标:找到系统在稳定运行&a…...
ORM 框架的优缺点分析
ORM 框架的优缺点分析 一、ORM 框架概述 ORM(Object-Relational Mapping)是一种将关系型数据库与面向对象编程进行映射的技术框架。它通过将数据库表映射为编程语言中的类,将记录映射为对象,将字段映射为属性,实现了用面向对象的方式操作数据库。 核心价值:ORM 在数据库和…...

【目标检测】【ICCV 2021】条件式DETR实现快速训练收敛
Conditional DETR for Fast Training Convergence 条件式DETR实现快速训练收敛 代码链接 论文链接 摘要 最近提出的DETR方法将Transformer编码器-解码器架构应用于目标检测领域,并取得了显著性能。本文针对其训练收敛速度慢这一关键问题,提出了一种条…...

【工作笔记】 WSL开启报错
【工作笔记】 WSL开启报错 时间:2025年5月30日16:50:42 1.现象 Installing, this may take a few minutes... WslRegisterDistribution failed with error: 0x80370114 Error: 0x80370114 ??????????????????Press any key to continue......

VMware使用时出现的问题,此文章会不断更新分享使用过程中会出现的问题
VMware使用时出现的问题,此文章会不断更新分享使用过程中会出现的问题 一、VMware安装后没有虚拟网卡,VMnet1,VMnet8显示黄色三角警告 此文章会不断更新,分享VMware使用过程中出现的问题 如果没找到你的问题可以私信我 一、VMware…...
UniApp微信小程序自定义导航栏实现
UniApp微信小程序自定义导航栏 在UniApp开发微信小程序时,页面左上角默认有一个返回按钮(在导航栏左侧),但有时我们需要自定义这个按钮的样式和功能,同时保持与导航栏中间的标题和右侧胶囊按钮(药丸屏&…...
【Ubuntu】Ubuntu网络管理
Ubuntu 网络管理 ubuntu/debian 中的网络管理 NetworkManager,使用nmcli查询与操作网络配置 /run/NetworkManager/no-stub-resolv.conf 对应命令行例子: nmcli device showsystemd-networkd,使用netplan的yaml文件来配置网络 /usr/lib/systemd/systemd-networkdsystemd-resol…...
GitHub 趋势日报 (2025年05月27日)
本日报由 TrendForge 系统生成 https://trendforge.devlive.org/ 🌐 本日报中的项目描述已自动翻译为中文 📈 今日整体趋势 Top 10 排名项目名称项目描述今日获星总星数语言1Fosowl/agenticSeek完全本地的马努斯AI。没有API,没有200美元的每…...
VR视角下,浙西南革命的热血重生
VR 浙西南革命项目依托先进的 VR 技术,为浙西南革命历史的展示开辟了一条全新的道路 ,打破了时间与空间的限制,使革命历史变得触手可及。 (一)沉浸式体验革命场景 借助 VR 技术,在 VR 浙西南革命的展示…...