Floyd算法的java实现
2016-03-28 19:19
423 查看
Floyd算法:用于多源最短路径的求解,算出来的是所有的节点到其余各节点之间的最短距离。
该算法的思路是:首先初始化距离矩阵,然后从第一个点开始逐渐更新矩阵点值。d[i][j]表示从i点到j点的距离。第k次更新时,判断d[i][k]+d[k][j]与d[i][j]的大小,如果前者小,则更新这个值,否则不变。
给一个例子:
具体的floyd实现算法如下:
在实现之后,针对上图的点和权值,给定一个测试:
该算法的思路是:首先初始化距离矩阵,然后从第一个点开始逐渐更新矩阵点值。d[i][j]表示从i点到j点的距离。第k次更新时,判断d[i][k]+d[k][j]与d[i][j]的大小,如果前者小,则更新这个值,否则不变。
给一个例子:
具体的floyd实现算法如下:
package com.blyang; public class Floyd { int[][] Matrix; char[] Nodes; private final int INF = Integer.MAX_VALUE; public Floyd(char[] Nodes, int[][] Matrix){ this.Nodes = Nodes; this.Matrix = Matrix; } public void floyd(){ int[][] distance = new int[Nodes.length][Nodes.length]; // 初始化距离矩阵 for(int i=0; i<Nodes.length; i++){ for(int j=0; j<Nodes.length; j++){ distance[i][j] = Matrix[i][j]; } } //循环更新矩阵的值 for(int k=0; k<Nodes.length; k++){ for(int i=0; i<Nodes.length; i++){ for(int j=0; j<Nodes.length; j++){ int temp = (distance[i][k] == INF || distance[k][j] == INF) ? INF : distance[i][k] + distance[k][j]; if(distance[i][j] > temp){ distance[i][j] = temp; } } } } // 打印floyd最短路径的结果 System.out.printf("floyd: \n"); for (int i = 0; i < Nodes.length; i++) { for (int j = 0; j < Nodes.length; j++) System.out.printf("%12d ", distance[i][j]); System.out.printf("\n"); } } }
在实现之后,针对上图的点和权值,给定一个测试:
package com.blyang; public class Main { public static void main(String[] args) { int INF = Integer.MAX_VALUE; char[] Nodes = {'0', '1', '2', '3'}; int matrix[][] = { /*A*//*B*//*C*//*D*/ /*A*/ { 0, 1, 2, 1}, /*B*/ { INF, 0, INF, INF}, /*C*/ { INF, 3, 0, 1}, /*D*/ { INF, 1, 1, 0}, }; int[] dist = new int[Nodes.length]; Floyd floyd = new Floyd(Nodes, matrix); floyd.floyd(); } }
相关文章推荐
- 白话Spring(中级篇)---注解(4)
- JavaWeb学习笔记——JavaEE基础知识
- spring mvc路径匹配原则
- SpringMVC拦截器(资源和权限管理)
- java对象属性和方法的引用
- Java第三次实验
- Java学习笔记2-JDBC存储过程
- 开发环境配置-eclipse安装反编译插件jadclipse-2
- java基础知识学习笔记(二)
- MyEclipse------带进度条的输入流
- 【java基础概念】(2016/3/28)
- mac上同时安装多个jdk,选择版本
- JAVA中关于DATE时间日期加减、String与Date类型的转换
- JavaWeb测试题总结
- Java 字节流与字符流的区别
- Spring的简单应用
- Java in Tarena_Spring Note04
- 开课第一天java
- activiti自定义流程之Spring整合activiti-modeler5.16实例(三):流程模型列表展示
- Java垃圾回收机制