news 2026/6/13 2:35:07

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/6/2 9:40:16

Hunyuan MT1.5-1.8B适用场景:轻量级翻译需求部署指南

Hunyuan MT1.5-1.8B适用场景&#xff1a;轻量级翻译需求部署指南 1. 引言 随着全球化进程的加速&#xff0c;高质量、低延迟的机器翻译需求日益增长&#xff0c;尤其是在移动设备、边缘计算和实时交互场景中。腾讯开源的混元翻译模型&#xff08;Hunyuan MT&#xff09;系列为…

作者头像 李华
网站建设 2026/6/12 2:10:46

HY-MT1.5一键部署推荐:Docker镜像免配置环境快速上手

HY-MT1.5一键部署推荐&#xff1a;Docker镜像免配置环境快速上手 随着多语言交流需求的不断增长&#xff0c;高质量、低延迟的翻译模型成为智能应用的核心组件。腾讯近期开源了其最新的混元翻译大模型系列——HY-MT1.5&#xff0c;包含两个版本&#xff1a;HY-MT1.5-1.8B 和 H…

作者头像 李华
网站建设 2026/5/30 13:33:15

Qwen3-VL多租户隔离:1张A100安全共享,成本均摊更划算

Qwen3-VL多租户隔离&#xff1a;1张A100安全共享&#xff0c;成本均摊更划算 1. 为什么需要多租户隔离&#xff1f; 想象一下孵化器里有5家初创公司&#xff0c;每家都需要AI能力来处理图像和文本任务。如果每家公司单独采购一张A100显卡&#xff0c;不仅成本高昂&#xff08…

作者头像 李华
网站建设 2026/6/10 0:32:30

HY-MT1.5-7B如何应对混合语言?真实场景翻译部署测试

HY-MT1.5-7B如何应对混合语言&#xff1f;真实场景翻译部署测试 1. 背景与问题提出 随着全球化进程加速&#xff0c;跨语言交流日益频繁&#xff0c;传统翻译模型在面对混合语言输入&#xff08;如中英夹杂、方言与标准语混用&#xff09;时常常表现不佳。用户在社交媒体、客…

作者头像 李华
网站建设 2026/6/6 11:40:18

基于springboot的山西高校毕业生信息咨询平台_w2i00tg5

文章目录摘要主要技术与实现手段系统设计与实现的思路系统设计方法java类核心代码部分展示结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;摘要 山西高校毕业生信息咨询平台基于SpringBoot框架开发&#xff0c;旨在为省内高校学生、用…

作者头像 李华
网站建设 2026/6/4 15:21:51

开源翻译模型新选择:HY-MT1.5全面评测报告

开源翻译模型新选择&#xff1a;HY-MT1.5全面评测报告 随着多语言交流需求的不断增长&#xff0c;高质量、低延迟的机器翻译模型成为AI应用落地的关键组件。传统商业翻译API虽具备一定性能优势&#xff0c;但在数据隐私、定制化能力和部署灵活性方面存在局限。在此背景下&…

作者头像 李华