最短路径算法:弗洛伊德(Floyd-Warshall)算法
一、算法介绍
Floyd-Warshall算法(英语:Floyd-Warshall algorithm),中文亦称弗洛伊德算法,是解决任意两点间的最短路径的一种算法,可以正确处理有向图或负权(但不可存在负权回路)的最短路径问题,同时也被用于计算有向图的传递闭包。Floyd-Warshall算法的时间复杂度为 O(N3),空间复杂度为 O(N2),因时间复杂度比较高,不适合计算大量数据。
二、算法原理
Floyd-Warshall算法的原理是动态规划,Floyd算法适用于APSP(All Pairs Shortest Paths,多源最短路径)。
设 Di,j,k 为从 i 到 j 的只以 (1..k) 集合中的节点为中间节点的最短路径的长度。
- 若最短路径经过点 k,则 Di,j,k = Di,k,k-1 + Dk,j,k-1;
- 若最短路径不经过点 k,则 Di,j,k =Di,j,k-1。
因此,Di,j,k = min (Di,j,k-1, Di,k,k-1 + Dk,j,k-1)。
1 for (k = 0; k < V; k++) {
2 for (i = 0; i < V; i++) {
3 for (j = 0; j < V; j++) {
4 if (dist[i][j] > dist[i][k] + dist[k][j]) {
5 dist[i][j] = dist[i][k] + dist[k][j];
6 }
7 }
8 }
9 }
输入矩阵:
1 int[][] graph = {
2 {0, 5, INF, 10},
3 {INF, 0, 3, INF},
4 {INF, INF, 0, 1},
5 {INF, INF, INF, 0}
6 };
输出结果:
1 Shortest distance matrix :
2 0 5 8 9
3 INF 0 3 4
4 INF INF 0 1
5 INF INF INF 0
初始化与输入图矩阵相同的求解矩阵。然后,我们通过将所有顶点视为中间顶点来更新解矩阵。这个思想是一个接一个地选取所有顶点并更新所有最短路径,其中包括所选取的顶点作为最短路径中的中间顶点。
源代码:
1 package algorithm.shortestpath;
2
3 public class AllPairShortestPath {
4 final static int INF = 99999, V = 4;
5
6 public void floydWarshall(int[][] graph) {
7 int[][] dist = new int[V][V];
8 int i, j ,k;
9 for (i = 0; i < V; i++) {
10 for (j = 0; j < V; j++) {
11 dist[i][j] = graph[i][j];
12 }
13 }
14 for (k = 0; k < V; k++) {
15 for (i = 0; i < V; i++) {
16 for (j = 0; j < V; j++) {
17 if (dist[i][j] > dist[i][k] + dist[k][j]) {
18 dist[i][j] = dist[i][k] + dist[k][j];
19 }
20 }
21 }
22 }
23 printSoultion(dist);
24 }
25
26 private void printSoultion(int[][] dist) {
27 System.out.println("The following matrix shows the shortest "+
28 "distances between every pair of vertices");
29 for (int i = 0; i < V; ++i) {
30 for (int j = 0; j < V; ++j) {
31 if (dist[i][j] == INF) {
32 System.out.print("INF ");
33 } else {
34 System.out.print(dist[i][j] + " ");
35 }
36 }
37 System.out.println();
38 }
39 }
40
41 public static void main(String[] args) {
42 /* 输入带权重矩阵
43 10
44 (0)------->(3)
45 | /|\
46 5 | |
47 | | 1
48 \|/ |
49 (1)------->(2)
50 3 */
51 int[][] graph = {
52 {0, 5, INF, 10},
53 {INF, 0, 3, INF},
54 {INF, INF, 0, 1},
55 {INF, INF, INF, 0}
56 };
57
58 AllPairShortestPath a = new AllPairShortestPath();
59
60 a.floydWarshall(graph);
61 }
62 }
最短路径算法:弗洛伊德(Floyd-Warshall)算法的更多相关文章
- 数据结构与算法——弗洛伊德(Floyd)算法
介绍 和 Dijkstra 算法一样,弗洛伊德(Floyd)算法 也是一种用于寻找给定的加权图中顶点间最短路径的算法.该算法名称以创始人之一.1978 年图灵奖获得者.斯坦福大学计算机科学系教授罗伯特 ...
- JS实现最短路径之弗洛伊德(Floyd)算法
弗洛伊德算法是实现最小生成树的一个很精妙的算法,也是求所有顶点至所有顶点的最短路径问题的不二之选.时间复杂度为O(n3),n为顶点数. 精妙之处在于:一个二重初始化,加一个三重循环权值修正,完成了所有 ...
- Floyd—Warshall算法
我们用DP来求解任意两点间的最短路问题 首先定义状态:d[k][i][k]表示使用顶点1~k,i,j的情况下,i到j的最短路径 (d[0][i][j]表示只使用i和j,因此d[0][i][j] = c ...
- 图论之最短路径(1)——Floyd Warshall & Dijkstra算法
开始图论学习的第二部分:最短路径. 由于知识储备还不充足,暂时不使用邻接表的方法来计算. 最短路径主要分为两部分:多源最短路径和单源最短路径问题 多源最短路径: 介绍最简单的Floyd Warshal ...
- 算法:最短路径之弗洛伊德(Floyd)算法
https://cloud.tencent.com/developer/article/1012420 为了能讲明白弗洛伊德(Floyd)算法的主要思想,我们先来看最简单的案例.图7-7-12的左图是 ...
- 最短路径 - 弗洛伊德(Floyd)算法
为了能讲明白弗洛伊德(Floyd)算法的主要思想,我们先来看最简单的案例.图7-7-12的左图是一个简单的3个顶点的连通网图. 我们先定义两个二维数组D[3][3]和P[3][3], D代表顶点与顶点 ...
- 图的最短路径---弗洛伊德(Floyd)算法浅析
算法介绍 和Dijkstra算法一样,Floyd算法也是为了解决寻找给定的加权图中顶点间最短路径的算法.不同的是,Floyd可以用来解决"多源最短路径"的问题. 算法思路 算法需要 ...
- 最短路径问题:弗洛伊德算法(Floyd)
Floyd算法 1.定义概览 Floyd-Warshall算法(Floyd-Warshall algorithm)是解决任意两点间的最短路径的一种算法,可以正确处理有向图或负权的最短路径问题,同时也被 ...
- 最短路径:Dijkstra & Floyd 算法图解,c++描述
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 最小生成树(prime算法 & kruskal算法)和 最短路径算法(floyd算法 & dijkstra算法)
一.主要内容: 介绍图论中两大经典问题:最小生成树问题以及最短路径问题,以及给出解决每个问题的两种不同算法. 其中最小生成树问题可参考以下题目: 题目1012:畅通工程 http://ac.jobdu ...
随机推荐
- ms sql 带自增列 带外键约束 数据导入导出
1,生成建表脚本 选中要导的表,点右键-编写表脚本为-create到 ,生成建表脚本 2,建表(在新库),但不建外键关系 不要选中生成外键的那部分代码,只选择建表的代码 3,导数据,用SQL STU ...
- scrum项目冲刺_day02总结
摘要:今日完成任务. 1.appUI页面完成 2.图像识别正在进行 总任务: 一.appUI页面(已完成) 二.首页功能: 1.图像识别功能 2.语音识别功能 3.垃圾搜索功能 4.相关新闻爬取 三. ...
- Spring Cloud Hystrix 学习(一)
在学习Hystrix之前,首先引入一个问题场景,服务雪崩.如下图所示: 可以看到,三个入口服务A.B.C最终都会请求到服务T.当服务T的请求过载,打满CPU都无法匹配请求的频率时,同步调用的上级服务就 ...
- Jmeter系类(32) - JSR223(2) | Groovy常见内置函数及调用
常见内置函数及调用 获取相关函数 获取返回数据并转换为String字符串 prev.getResponseDataAsString() 例子 String Responsedata = prev.ge ...
- Linux系列(25) - 常用快捷键(未更新完)
快捷键 说明 Ctrl+L 清屏 tab tab按一次自动补全目录文件名称/tab按二次将目录下带有补全前面字段的所有文件目录展示出来,例子: cd / tab键按两次将根目录下所有文件展示出来 ...
- Shell系列(14)- declare声明变量
declare声明变量类型 格式 declare [+/-] [选项] [变量名] 选项 -:给变量设定类型属性 +:取消变量的类型属性 -a :将变量声明为数组型 -i :将变量声明为整数型(int ...
- Spring Cloud Gateway 没有链路信息,我 TM 人傻了(中)
本系列是 我TM人傻了 系列第五期[捂脸],往期精彩回顾: 升级到Spring 5.3.x之后,GC次数急剧增加,我TM人傻了 这个大表走索引字段查询的 SQL 怎么就成全扫描了,我TM人傻了 获取异 ...
- python3.7发送邮件带附件
代码: 1 # -*- coding: utf-8 -*- 2 3 import smtplib, ssl 4 from email.mime.text import MIMEText 5 from ...
- 老板说,你给我1分钟内下载1000张图片!So,easy!
上班的某一天,领导过来说!你帮下载一些图片资源,我以为就几张来着,原来是几十百来个网站要去保存图片!是要我把搞!!! 我们最常规的做法就是通过鼠标右键,选择另存为.但有些图片鼠标右键的时候并没有另存为 ...
- 10.11 HTTPS
没有HTTPS的抓包截图 HTTPS=HTTP + TLS/SSL https 实现过程如下 1.客户端发起HTTPS请求 rewrite www.baidu.com https://www.baid ...