news 2026/2/25 19:49:49

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/2/24 14:12:20

混元翻译1.5格式化翻译:结构化文本处理指南

混元翻译1.5格式化翻译&#xff1a;结构化文本处理指南 1. 引言&#xff1a;混元翻译模型的演进与定位 随着全球化进程加速&#xff0c;高质量、多语言互译能力已成为自然语言处理&#xff08;NLP&#xff09;领域的重要基础设施。在这一背景下&#xff0c;腾讯推出了开源翻译…

作者头像 李华
网站建设 2026/2/18 14:19:45

腾讯Hunyuan模型部署难?镜像开箱即用教程来解答

腾讯Hunyuan模型部署难&#xff1f;镜像开箱即用教程来解答 1. 引言&#xff1a;从开源翻译模型到开箱即用的实践突破 随着大模型在自然语言处理领域的持续演进&#xff0c;高质量、低延迟的机器翻译需求日益增长。腾讯推出的 HY-MT1.5 系列翻译模型&#xff0c;作为其 Hunyua…

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

HY-MT1.5-7B结构化输出:数据库直接导入

HY-MT1.5-7B结构化输出&#xff1a;数据库直接导入 1. 引言 随着全球化进程的加速&#xff0c;高质量、低延迟的机器翻译需求日益增长。腾讯近期开源了其混元翻译大模型系列的最新版本——HY-MT1.5&#xff0c;包含两个核心模型&#xff1a;HY-MT1.5-1.8B 和 HY-MT1.5-7B。这…

作者头像 李华
网站建设 2026/2/21 5:55:48

davhlpr.dll文件丢失找不到问题 免费下载文件方法分享给你

在使用电脑系统时经常会出现丢失找不到某些文件的情况&#xff0c;由于很多常用软件都是采用 Microsoft Visual Studio 编写的&#xff0c;所以这类软件的运行需要依赖微软Visual C运行库&#xff0c;比如像 QQ、迅雷、Adobe 软件等等&#xff0c;如果没有安装VC运行库或者安装…

作者头像 李华
网站建设 2026/2/24 3:08:42

腾讯开源HY-MT1.5部署指南:4090D显卡配置详解

腾讯开源HY-MT1.5部署指南&#xff1a;4090D显卡配置详解 1. 引言 随着多语言交流需求的不断增长&#xff0c;高质量、低延迟的机器翻译模型成为智能应用的核心组件。腾讯近期开源了其混元翻译大模型1.5版本&#xff08;HY-MT1.5&#xff09;&#xff0c;包含两个关键模型&…

作者头像 李华
网站建设 2026/2/7 16:57:16

Qwen3-VL智能标注工具:云端GPU加速,标注效率提升5倍

Qwen3-VL智能标注工具&#xff1a;云端GPU加速&#xff0c;标注效率提升5倍 1. 为什么你需要Qwen3-VL智能标注工具 作为数据标注团队的负责人&#xff0c;你一定深有体会&#xff1a;传统人工标注不仅耗时费力&#xff0c;而且面对复杂图像时标注质量难以保证。Qwen3-VL是阿里…

作者头像 李华