news 2026/3/7 11:32:59

Floyd算法这玩意儿挺有意思的,它就像个热心肠的交通协管员,拿着地图挨个路口问:“从这儿到那儿走我这个路口是不是更近?“ 咱们直接来看代码骨架

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Floyd算法这玩意儿挺有意思的,它就像个热心肠的交通协管员,拿着地图挨个路口问:“从这儿到那儿走我这个路口是不是更近?“ 咱们直接来看代码骨架

floyd算法求最小距离代码

def floyd(graph): n = len(graph) dist = [[0]*n for _ in range(n)] # 初始化距离矩阵 for i in range(n): for j in range(n): dist[i][j] = graph[i][j] # 三重循环暴力更新 for k in range(n): for i in range(n): for j in range(n): if dist[i][k] + dist[k][j] < dist[i][j]: dist[i][j] = dist[i][k] + dist[k][j] return dist

这个初始化部分有个小细节容易被新手忽略——为什么要单独搞个dist矩阵而不是直接修改原图?想象一下你在更新A到C的距离时,如果直接改原矩阵,后面的B到D的计算可能就用了被污染的数据。这种"数据污染防护"机制挺重要。

中间那个三重循环看起来吓人,其实可以拆解来看。假设现在要计算北京到广州的最短距离,k=武汉这个中间站。算法会先问:"北京->武汉->广州 比 北京直达广州 近吗?"如果近就更新。接着k换成郑州、长沙...直到所有可能的中转站都检查一遍。

来看看具体更新逻辑:

if dist[i][k] + dist[k][j] < dist[i][j]: dist[i][j] = dist[i][k] + dist[k][j]

这行代码藏着动态规划的精髓——最优子结构。就像拼乐高,大问题(i到j)的解建立在更小子问题(i到k和k到j)的最优解之上。不过要注意这里的k遍历顺序,最外层必须是中间节点,这个顺序如果搞反了算法就废了。

实际应用时可以加点路径追踪功能。我们可以在初始化时创建个path矩阵:

path = [[-1]*n for _ in range(n)] if dist[i][j] > dist[i][k] + dist[k][j]: dist[i][j] = dist[i][k] + dist[k][j] path[i][j] = k # 记录关键转折点

这样要查具体路径时,就可以用递归把路径拆成i->k和k->j两段,直到找到-1标识的直达路线。

虽然时间复杂度O(n³)看着吓人,但在实际项目中处理几百个节点的图还是能hold住的。不过要注意输入图的表示方式,如果节点太多建议换稀疏矩阵存储。对了,算法处理负权边时要当心,万一图里有负权环就完犊子了,这时候得用其他法子。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/5 0:23:30

HY-MT1.5-1.8B实战:资源受限环境部署技巧

HY-MT1.5-1.8B实战&#xff1a;资源受限环境部署技巧 1. 引言 随着多语言交流需求的不断增长&#xff0c;高质量、低延迟的翻译模型成为智能设备、边缘计算和实时通信场景中的关键技术。腾讯近期开源了混元翻译大模型1.5版本&#xff08;HY-MT1.5&#xff09;&#xff0c;其中…

作者头像 李华
网站建设 2026/3/8 9:24:30

HY-MT1.5镜像部署避坑指南:常见报错与解决方案汇总

HY-MT1.5镜像部署避坑指南&#xff1a;常见报错与解决方案汇总 1. 引言 随着多语言交流需求的不断增长&#xff0c;高质量、低延迟的翻译模型成为智能应用的核心组件。腾讯开源的混元翻译大模型 HY-MT1.5 系列&#xff0c;凭借其在多语言互译、边缘部署和上下文理解方面的突出…

作者头像 李华
网站建设 2026/3/4 9:18:28

腾讯开源模型应用:HY-MT1.5教育领域

腾讯开源模型应用&#xff1a;HY-MT1.5教育领域 1. 引言 随着全球化进程的加速&#xff0c;跨语言交流在教育、科研和国际合作中变得愈发重要。然而&#xff0c;传统翻译工具在面对复杂语境、混合语言表达以及专业术语时&#xff0c;往往表现不佳&#xff0c;难以满足高质量翻…

作者头像 李华
网站建设 2026/2/27 19:00:48

混元翻译1.5模型实战:跨境电商Listing优化

混元翻译1.5模型实战&#xff1a;跨境电商Listing优化 在跨境电商日益全球化的今天&#xff0c;高质量、本地化精准的商品Listing翻译已成为提升转化率的关键环节。传统机器翻译工具往往难以准确传达产品特性&#xff0c;尤其在处理多语言混合、专业术语密集或文化语境敏感的内…

作者头像 李华
网站建设 2026/3/6 9:46:56

基于PLC变频调速供水系统的设计

2 恒压供水系统 2.1 变频恒压供水系统 变频恒压供水系统能适用生活水、工业用水以及消防用水等多种场合的供水要求&#xff0c;该系统具有以下特点&#xff1a; &#xff08;1&#xff09;供水系统的控制对象是用户管网的水压&#xff0c;它是一个过程控制量&#xff0c;同其他…

作者头像 李华
网站建设 2026/3/3 1:45:46

解读具身智能系统为什么必须“在约束下可行”

“把约束当作认知机制的一部分”&#xff0c;本该是具身认知的第一性原理。在工程领域&#xff0c;我们很少会否认一个常识&#xff1a; 任何真实运行的系统&#xff0c;都是在约束中工作的。有带宽限制&#xff0c;有时延&#xff0c;有噪声&#xff1b; 有物理边界&#xff0…

作者头像 李华