4 Star 0 Fork 0

李小蒙/project

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
第五个功能(部分1) 1.69 KB
一键复制 编辑 原始数据 按行查看 历史
李昊炎 提交于 2021-12-22 15:34 +08:00 . add 第五个功能(部分1).
package KS;
import java.util.ArrayList;
import java.util.List;
public class FloydInGraph {
/**
* 邻接矩阵 最短路径 弗洛伊德算法
*/
public static int INF=Integer.MAX_VALUE;
//dist[i][j]=INF<==>no edges between i and j
public int[][] dist;
//the distance between i and j.At first,dist[i][j] is the weight of edge [i,j]
public int[][] path;
public List<Integer> result=new ArrayList<Integer>();
public void findCheapestPath(int begin,int end,int[][] matrix){
floyd(matrix);
result.add(begin);
findPath(begin,end);
result.add(end);
}
public void findPath(int i,int j){
int k=path[i][j];
if(k==-1)return;
findPath(i,k);
result.add(k);
findPath(k,j);
}
public void floyd(int[][] matrix){
int size=matrix.length;
//initialize dist and path
for(int i=0;i<size;i++){
for(int j=0;j<size;j++){
path[i][j]=-1;
dist[i][j]=matrix[i][j];
}
}
for(int k=0;k<size;k++){
for(int i=0;i<size;i++){
for(int j=0;j<size;j++){
if(dist[i][k]!=INF&&
dist[k][j]!=INF&&
dist[i][k]+dist[k][j]<dist[i][j]){//dist[i][k]+dist[k][j]>dist[i][j]-->longestPath
dist[i][j]=dist[i][k]+dist[k][j];
path[i][j]=k;
}
}
}
}
}
public FloydInGraph(int size){
this.path=new int[size][size];
this.dist=new int[size][size];
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/li-xiaomeng_01/project.git
git@gitee.com:li-xiaomeng_01/project.git
li-xiaomeng_01
project
project
master

搜索帮助

371d5123 14472233 46e8bd33 14472233