python实现 最短路径算法

python实现 最短路径算法一、Floyd-Warshall算法1.算法简介Floyd-Warshall算法是解决任意两点间的最短路径的一种算法。通常可以在任何图中使用,包括有向图、带负权边的图。存储方式采用邻接矩阵2.示例0 1 2 6 3 1 0 3 5 2 2 3 0 8 5 6 5 8 0 …

大家好,又见面了,我是你们的朋友全栈君。

一、Floyd-Warshall算法

1.算法简介

Floyd-Warshall算法是解决任意两点间的最短路径的一种算法。通常可以在任何图中使用,包括有向图带负权边的图。

存储方式采用邻接矩阵

2.示例

0 1 2 6 3
1 0 3 5 2
2 3 0 8 5
6 5 8 0 3
3 2 5 3 0

 

3.代码实现

import math


nodes = ('A', 'B', 'C', 'D', 'E')
# dis矩阵为方阵
dis = [[0,1,2,math.inf,4],
       [1,0,math.inf,8,2],
       [2,math.inf,0,math.inf,6],
       [math.inf,8,math.inf,0,3],
       [4,2,6,3,0]]

def shortDistance(dis):
    node_num = len(dis)
    for i in range(node_num):         # 十字交叉法的位置位置,先列后行
        for j in range(node_num):     # 列 表示dis[j][i]的值,即j->i
            for k in range(j+1, node_num): # 行 表示dis[i][k]的值,即i->k,i只是一个桥梁而已
                # 先列后行,形成一个传递关系,若比原来距离小,则更新
                if dis[j][k] > dis[j][i] + dis[i][k]:
                    dis[j][k] = dis[j][i] + dis[i][k]
                    dis[k][j] = dis[j][i] + dis[i][k]

二、分支界限算法

1.定义(解决单源最短路径问题)

贪婪算法一样,这种方法也是用来为组合优化问题设计求解算法的,所不同的是它在问题的整个可能解空间搜索,所设计出来的算法虽其时间复杂度比贪婪算法高,但它的优点是与穷举法类似,都能保证求出问题的最佳解,而且这种方法不是盲目的穷举搜索,而是在搜索过程中通过限界,可以中途停止对某些不可能得到最优解的子空间进一步搜索(类似于人工智能中的剪枝),故它比穷举法效率更高。

2.优点

(1)边权可负(但是负权环路会造成死循环),而Dijkstra不行;

(2)保证最优解。

3.示例

è¿éåå¾çæè¿°

分支界限解决策略

è¿éåå¾çæè¿°

 

# 分支界限计算最短路径和最短路径长度
import math
from copy import deepcopy
# 初始化图参数 用字典初始初始化这个图
graph = {1: { 2: 4, 3: 2,4:5},
     2: {5: 7, 6: 5},
     3: {6: 9},
     4: {5: 2, 7: 7},
     5: {8: 4},
     6: {10:6},
     7: {9: 3},
     8: {10:7},
     9: {10:8},
     10:{}
    }

# 分支界限:计算起始节点到其他所有节点的最短距离
"""
1.将起始节点入队,并且初始化起始节点到其他所有节点距离为inf,用costs
2.检测起始节点的到子节点的距离是否变短,若是,则将其子节点入队
3.子节点全部检测完,则将起始节点出队,
4.让队列中的第一个元素作为新的起始节点,重复1,2,3,4
5.对队列为空,则退出循环
"""
# 数据结构:队列,树
def banch(graph, start):

    costs = {}                # 记录start到其他所有点的距离
    trace = {start:[start]}   # 记录start到其他所有点的路径

    # 初始化costs
    for key in graph.keys():
        costs[key] = math.inf
    costs[start] = 0
    
    queue = [start]          # 初始化queue
    
    while len(queue) != 0:
        head = queue[0]                # 起始节点
        for key in graph[head].keys(): # 遍历起始节点的子节点
            dis = graph[head][key] + costs[head]
            if costs[key] > dis:
                costs[key] = dis
                temp = deepcopy(trace[head])  # 深拷贝
                temp.append(key)        
                trace[key] = temp# key节点的最优路径为起始节点最优路径+key
                queue.append(key)

        queue.pop(0)                   # 删除原来的起始节点
    print(costs)
    print(trace)
banch(graph, 1)

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/136250.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月3日 下午9:46
下一篇 2022年6月3日 下午9:46


相关推荐

  • 数据标准化/归一化normalization

    数据标准化/归一化normalizationhttp://blog.csdn.net/pipisorry/article/details/52247379这里主要讲连续型特征归一化的常用方法。连续型特征还有一种处理方式是,先分桶/分箱(如等频/等距的分)[待写]进行离散化后再使用离散数据的处理方法。离散数据处理参考[数据预处理:独热编码(One-HotEncoding)]。基础知识参考:[均值、方差与协方差矩阵][…

    2022年6月23日
    28
  • java的正向代理和反向代理

    java的正向代理和反向代理一 正向代理在我们生活中有很多代理的例子 nbsp nbsp nbsp nbsp nbsp nbsp 租房子找中介 中介就是一个代理 nbsp nbsp nbsp nbsp nbsp nbsp 打扫房屋找清洁公司 清洁公司就是一个代理 nbsp nbsp nbsp nbsp nbsp nbsp 相亲找媒婆 媒婆就是一个代理 要了解 java 的正向代理先来以下的一个例子 nbsp nbsp nbsp nbsp nbsp nbsp 我是一个用户 A 访问不了某网站 服务器 B 但是我能访问一个代理服务器 Z 而这个代理服务器 Z 能访问那个我不能访问的网站 服务器 B 于是我先连上代

    2026年3月26日
    2
  • EXTJS 教程目录

    EXTJS 教程目录  本人开发extjs有两三个月了,做了三个左右的项目,其中后台都是用它来完成的。现在想借此机会整理一下用extjs开发的一些思维。  其实本人并没有完全地看过一本extjs的书籍,只是在开发过程中遇到什么问题就去百度什么。结果到现在开发时基本的东西都记不住,每次都是从旧项目中拷贝要用的东西出来,结果效率很慢。ps:以下教程都是采用extjs3.4都编写的  言归正传,以下的目录…

    2022年6月21日
    27
  • Git安装与配置(mac版本)

    Git安装与配置(mac版本)教程目录 0x00 教程内容 0x01Git 的下载与安装 1 下载 2 安装 0x02Git 的配置 1 配置用户名和用户邮箱 0x03 校验 Git0xFF 总结 0x00 教程内容说明 我安装的 Git 版本是 2 16 2 教程参考 MAC 端 Git 安装以及环境搭建 0x01Git 的下载与安装 1 下载 a 方式一之官网下载 保险期间还是用这种方式好点咯 https www git

    2025年10月20日
    9
  • Android Studio中的Instant Run

    Android Studio中的Instant RunAndroidStudi 3 版本过后提供了一种 InstantRun 立即运行 运行机制 大大提高了应用程序从编译 到运行的速度 它能在不重启应用程序的情况下 把代码修改直接运行 有时候甚至不用重启 Activity 下面来谈谈如何使用这个功能 首先使用这个功能的前提是 1 targetSdkVer 必须 gt 212 androidplugi

    2026年3月18日
    1
  • OpenAI们吹爆的“员工智能体”,真的来了吗?

    OpenAI们吹爆的“员工智能体”,真的来了吗?

    2026年3月16日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号