news 2026/4/16 12:36:41

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/4/16 9:06:59

HY-MT1.5翻译质量提升:后处理技巧大全

HY-MT1.5翻译质量提升&#xff1a;后处理技巧大全 随着多语言交流需求的不断增长&#xff0c;高质量机器翻译成为跨语言沟通的核心支撑。腾讯开源的混元翻译大模型 HY-MT1.5 系列&#xff0c;凭借其在翻译准确性和场景适应性上的显著表现&#xff0c;迅速在开发者社区中引起广…

作者头像 李华
网站建设 2026/4/16 4:48:05

【RL】importance_sampling Ratio的计算

好的&#xff0c;我们来详细解释 clipfrac (clipping fraction) 在代码中是如何计算的。这个指标衡量了在PPO损失计算中&#xff0c;有多大比例的token因为ratio超出范围而被裁剪。 clipfrac 的计算通常在 ActorWorker.loss_func 方法内部&#xff0c;紧随着PPO损失的核心计算步…

作者头像 李华
网站建设 2026/4/15 13:54:38

Hunyuan-HY-MT1.5镜像推荐:免配置部署支持民族语言翻译实战测评

Hunyuan-HY-MT1.5镜像推荐&#xff1a;免配置部署支持民族语言翻译实战测评 近年来&#xff0c;随着多语言交流需求的不断增长&#xff0c;高质量、低延迟的翻译模型成为跨语言沟通的关键基础设施。特别是在中国这样一个多民族国家&#xff0c;对少数民族语言的支持不仅是技术…

作者头像 李华
网站建设 2026/4/16 11:15:15

d3dx10_38.dll文件丢失找不到问题 彻底解决办法分享给你

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

作者头像 李华
网站建设 2026/4/16 11:10:27

腾讯混元翻译模型1.5:民族语言支持部署教程

腾讯混元翻译模型1.5&#xff1a;民族语言支持部署教程 1. 引言 随着全球化进程的加速&#xff0c;跨语言沟通需求日益增长&#xff0c;尤其是在多民族、多方言共存的中国社会&#xff0c;对高质量、低延迟、支持小语种的翻译系统提出了更高要求。传统商业翻译API虽然覆盖广泛…

作者头像 李华