欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中的弗洛伊德(Floyd)算法

 更新時(shí)間:2024年01月15日 11:15:40   作者:Mu_Mu是一只小白  
這篇文章主要介紹了Java中的弗洛伊德(Floyd)算法,Floyd算法又稱(chēng)為插點(diǎn)法,是一種利用動(dòng)態(tài)規(guī)劃的思想尋找給定的加權(quán)圖中多源點(diǎn)之間最短路徑的算法,與Dijkstra算法類(lèi)似,需要的朋友可以參考下

弗洛伊德Floyd算法

Floyd算法又稱(chēng)為插點(diǎn)法,是一種利用動(dòng)態(tài)規(guī)劃的思想尋找給定的加權(quán)圖中多源點(diǎn)之間最短路徑的算法,與Dijkstra算法類(lèi)似。

該算法名稱(chēng)以創(chuàng)始人之一、1978年圖靈獎(jiǎng)獲得者、斯坦福大學(xué)計(jì)算機(jī)科學(xué)系教授羅伯特·弗洛伊德命名。

Dijkstra算法是求一個(gè)出發(fā)節(jié)點(diǎn)到其他各節(jié)點(diǎn)的最短距離,而Floyd算法是求每個(gè)節(jié)點(diǎn)到其他個(gè)節(jié)點(diǎn)的最短距離

在這里插入圖片描述

完整java代碼:

package com.yg.algorithm;/*
@author  Mu_Mu
@date    2020/3/23  9:56
*/
public class FloydAlgorithm {
    private static final int MAX=10000;
    public static void main(String[] args) {
        char[] vertexs = {'A', 'B', 'C', 'D', 'E'};
        int[][] matrix = {{0, MAX, MAX, 5, 2}, {MAX, 0, 8, MAX, 3}
                , {MAX, 8, 0, MAX, 4}, {5, MAX, MAX, 0, 9},{2,3,4,9,0}};
        FGraph fGraph = new FGraph(vertexs, matrix);
        fGraph.floyd();
        fGraph.show();
    }
}
class FGraph {
    private char[]vertexs;//存放頂點(diǎn)
    private int [][]dis;//每個(gè)頂點(diǎn)之間的距離
    private int[][]pre;//存放前驅(qū)頂點(diǎn)
    public FGraph(char[] vertexs, int[][] dis) {
        this.vertexs = vertexs;
        this.dis = dis;
        pre=new int [vertexs.length][vertexs.length];
        //初始化前驅(qū)頂點(diǎn)
        for (int i = 0; i < vertexs.length; i++) {
            for (int j = 0; j < vertexs.length; j++) {
                pre[i][j]=i;
            }
        }
    }
    //弗洛伊德算法
    public void floyd() {
        int len=0;
        //i,遍歷中間頂點(diǎn),3層循環(huán)的意義就是j通過(guò)i到k
        for (int i = 0; i < vertexs.length; i++) {
            //j代表出發(fā)節(jié)點(diǎn)
            for (int j = 0; j < vertexs.length; j++) {
                //k代表終點(diǎn)頂點(diǎn)
                for (int k = 0; k < vertexs.length; k++) {
                    //記錄j通過(guò)i到k的距離
                    len=dis[j][i]+dis[i][k];
                    //比較j通過(guò)i到k的距離是否小于j直接到k的距離
                    if (len < dis[j][k]) {
                        dis[j][k]=len;
                        pre[j][k]=pre[i][k];
                    }
                }
            }
        }
    }
    //打印圖
    public void show() {
        for (int i = 0; i < vertexs.length; i++) {
            //打印前驅(qū)頂點(diǎn)
            for (int j = 0; j < vertexs.length; j++) {
                System.out.print(vertexs[pre[i][j]]+"  ");
            }
            System.out.println();
           //打印頂點(diǎn)之間的距離
                for (int k = 0; k < vertexs.length; k++) {
                    System.out.print(vertexs[i]+"到"+vertexs[k]+"的距離為:"+dis[i][k]+"  ");
                }
            System.out.println();
        }
        }
    }

到此這篇關(guān)于Java中的弗洛伊德(Floyd)算法的文章就介紹到這了,更多相關(guān)弗洛伊德Floyd算法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論