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

Java實(shí)現(xiàn)Dijkstra算法的示例代碼

 更新時(shí)間:2022年07月08日 08:39:42   作者:chengqiuming  
Dijkstra(迪杰斯特拉)算法是典型的單源最短路徑算法,用于計(jì)算一個(gè)節(jié)點(diǎn)到其他所有節(jié)點(diǎn)的最短路徑。本文主要介紹了實(shí)現(xiàn)這一算法的Java代碼,需要的可以參考一下

一 問題描述

小明為位置1,求他到其他各頂點(diǎn)的距離。

二 實(shí)現(xiàn)

package graph.dijkstra;
 
import java.util.Scanner;
import java.util.Stack;
 
public class Dijkstra {
    static final int MaxVnum = 100;  // 頂點(diǎn)數(shù)最大值
    static final int INF = 0x3f3f3f3f; //無窮大
    static final int dist[] = new int[MaxVnum]; // 最短距離
    static final int p[] = new int[MaxVnum]; // 前驅(qū)數(shù)組
    static final boolean flag[] = new boolean[MaxVnum]; // 如果 s[i] 等于 true,說明頂點(diǎn) i 已經(jīng)加入到集合 S ;否則頂點(diǎn) i 屬于集合 V-S
 
    static int locatevex(AMGraph G, char x) {
        for (int i = 0; i < G.vexnum; i++) // 查找頂點(diǎn)信息的下標(biāo)
            if (x == G.Vex[i])
                return i;
        return -1; // 沒找到
    }
 
    static void CreateAMGraph(AMGraph G) {
        Scanner scanner = new Scanner(System.in);
        int i, j;
        char u, v;
        int w;
        System.out.println("請(qǐng)輸入頂點(diǎn)數(shù):");
        G.vexnum = scanner.nextInt();
        System.out.println("請(qǐng)輸入邊數(shù):");
        G.edgenum = scanner.nextInt();
        System.out.println("請(qǐng)輸入頂點(diǎn)信息:");
 
        // 輸入頂點(diǎn)信息,存入頂點(diǎn)信息數(shù)組
        for (int k = 0; k < G.vexnum; k++) {
            G.Vex[k] = scanner.next().charAt(0);
        }
        //初始化鄰接矩陣所有值為0,如果是網(wǎng),則初始化鄰接矩陣為無窮大
        for (int m = 0; m < G.vexnum; m++)
            for (int n = 0; n < G.vexnum; n++)
                G.Edge[m][n] = INF;
 
        System.out.println("請(qǐng)輸入每條邊依附的兩個(gè)頂點(diǎn)及權(quán)值:");
        while (G.edgenum-- > 0) {
            u = scanner.next().charAt(0);
            v = scanner.next().charAt(0);
            w = scanner.nextInt();
 
            i = locatevex(G, u);// 查找頂點(diǎn) u 的存儲(chǔ)下標(biāo)
            j = locatevex(G, v);// 查找頂點(diǎn) v 的存儲(chǔ)下標(biāo)
            if (i != -1 && j != -1)
                G.Edge[i][j] = w; //有向圖鄰接矩陣
            else {
                System.out.println("輸入頂點(diǎn)信息錯(cuò)!請(qǐng)重新輸入!");
                G.edgenum++; // 本次輸入不算
            }
        }
    }
 
    static void print(AMGraph G) { // 輸出鄰接矩陣
        System.out.println("圖的鄰接矩陣為:");
        for (int i = 0; i < G.vexnum; i++) {
            for (int j = 0; j < G.vexnum; j++)
                System.out.print(G.Edge[i][j] + "\t");
            System.out.println();
        }
    }
 
    public static void main(String[] args) {
        AMGraph G = new AMGraph();
        int st;
        char u;
        CreateAMGraph(G);
        System.out.println("請(qǐng)輸入源點(diǎn)的信息:");
        Scanner scanner = new Scanner(System.in);
        u = scanner.next().charAt(0);
        ;
        st = locatevex(G, u);//查找源點(diǎn)u的存儲(chǔ)下標(biāo)
        Dijkstra(G, st);
        System.out.println("小明所在的位置:" + u);
 
        for (int i = 0; i < G.vexnum; i++) {
            System.out.print("小明:" + u + " - " + "要去的位置:" + G.Vex[i]);
 
            if (dist[i] == INF)
                System.out.print(" sorry,無路可達(dá)");
            else
                System.out.println(" 最短距離為:" + dist[i]);
        }
        findpath(G, u);
    }
 
    public static void Dijkstra(AMGraph G, int u) {
        for (int i = 0; i < G.vexnum; i++) {
            dist[i] = G.Edge[u][i]; //初始化源點(diǎn)u到其他各個(gè)頂點(diǎn)的最短路徑長(zhǎng)度
            flag[i] = false;
            if (dist[i] == INF)
                p[i] = -1; //源點(diǎn)u到該頂點(diǎn)的路徑長(zhǎng)度為無窮大,說明頂點(diǎn)i與源點(diǎn)u不相鄰
            else
                p[i] = u; //說明頂點(diǎn)i與源點(diǎn)u相鄰,設(shè)置頂點(diǎn)i的前驅(qū)p[i]=u
        }
        dist[u] = 0;
        flag[u] = true;   //初始時(shí),集合S中只有一個(gè)元素:源點(diǎn)u
        for (int i = 0; i < G.vexnum; i++) {
            int temp = INF, t = u;
            for (int j = 0; j < G.vexnum; j++) //在集合V-S中尋找距離源點(diǎn)u最近的頂點(diǎn)t
                if (!flag[j] && dist[j] < temp) {
                    t = j;
                    temp = dist[j];
                }
            if (t == u) return; //找不到t,跳出循環(huán)
            flag[t] = true;  //否則,將t加入集合
            for (int j = 0; j < G.vexnum; j++)//更新V-S中與t相鄰接的頂點(diǎn)到源點(diǎn)u的距離
                if (!flag[j] && G.Edge[t][j] < INF)
                    if (dist[j] > (dist[t] + G.Edge[t][j])) {
                        dist[j] = dist[t] + G.Edge[t][j];
                        p[j] = t;
                    }
        }
    }
 
    public static void findpath(AMGraph G, char u) {
        int x;
        Stack<Integer> S = new Stack<>();
        System.out.println("源點(diǎn)為:" + u);
 
        for (int i = 0; i < G.vexnum; i++) {
            x = p[i];
            if (x == -1 && u != G.Vex[i]) {
                System.out.println("源點(diǎn)到其它各頂點(diǎn)最短路徑為:" + u + "--" + G.Vex[i] + "    sorry,無路可達(dá)");
                continue;
            }
            while (x != -1) {
                S.push(x);
                x = p[x];
            }
            System.out.println("源點(diǎn)到其它各頂點(diǎn)最短路徑為:");
            while (!S.empty()) {
                System.out.print(G.Vex[S.peek()] + "--");
                S.pop();
            }
            System.out.println(G.Vex[i] + "    最短距離為:" + dist[i]);
        }
    }
}
 
class AMGraph {
    char Vex[] = new char[Dijkstra.MaxVnum];
    int Edge[][] = new int[Dijkstra.MaxVnum][Dijkstra.MaxVnum];
    int vexnum; // 頂點(diǎn)數(shù)
    int edgenum; // 邊數(shù)
}

三 測(cè)試

到此這篇關(guān)于Java實(shí)現(xiàn)Dijkstra算法的示例代碼的文章就介紹到這了,更多相關(guān)Java Dijkstra算法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java簡(jiǎn)單從文件讀取和輸出的實(shí)例

    Java簡(jiǎn)單從文件讀取和輸出的實(shí)例

    下面小編就為大家?guī)硪黄狫ava簡(jiǎn)單從文件讀取和輸出的實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-09-09
  • maven項(xiàng)目在svn中的上傳與檢出的方法

    maven項(xiàng)目在svn中的上傳與檢出的方法

    企業(yè)開發(fā)中經(jīng)常使用svn來為我們控制代碼版本,也經(jīng)常使用maven來管理項(xiàng)目。下面將介紹一下如何將maven項(xiàng)目上傳到svn中,如何將項(xiàng)目從svn中檢出,感興趣的小伙伴們可以參考一下
    2019-02-02
  • Java通過python命令執(zhí)行DataX任務(wù)的實(shí)例

    Java通過python命令執(zhí)行DataX任務(wù)的實(shí)例

    今天小編就為大家分享一篇Java通過python命令執(zhí)行DataX任務(wù)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08
  • Redisson分布式鎖的源碼解讀分享

    Redisson分布式鎖的源碼解讀分享

    Redisson是一個(gè)在Redis的基礎(chǔ)上實(shí)現(xiàn)的Java駐內(nèi)存數(shù)據(jù)網(wǎng)格(In-Memory?Data?Grid)。Redisson有一樣功能是可重入的分布式鎖。本文來討論一下這個(gè)功能的特點(diǎn)以及源碼分析
    2022-11-11
  • MyBatis高級(jí)映射ResultMap解決屬性問題

    MyBatis高級(jí)映射ResultMap解決屬性問題

    對(duì)于數(shù)據(jù)庫中對(duì)表的增刪改查操作,我們知道增刪改都涉及的是單表,而只有查詢操作既可以設(shè)計(jì)到單表操作又可以涉及到多表操作,所以對(duì)于輸入映射parameterType而言是沒有所謂的高級(jí)映射的,也就是說高級(jí)映射只針對(duì)于輸出映射
    2023-02-02
  • SpringBoot集成Mybatis實(shí)現(xiàn)對(duì)多數(shù)據(jù)源訪問原理

    SpringBoot集成Mybatis實(shí)現(xiàn)對(duì)多數(shù)據(jù)源訪問原理

    本文主要分析討論在SpringBoot應(yīng)用中我們?cè)撊绾闻渲肧qlSessionFactoryBean對(duì)象,進(jìn)而實(shí)現(xiàn)對(duì)多個(gè)不同的數(shù)據(jù)源的操縱,文章通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • Spring Boot高可用限流三種實(shí)現(xiàn)解決方案

    Spring Boot高可用限流三種實(shí)現(xiàn)解決方案

    限流是對(duì)某一時(shí)間窗口內(nèi)的請(qǐng)求數(shù)進(jìn)行限制,保持系統(tǒng)的可用性和穩(wěn)定性,本文就介紹了Spring Boot高可用限流三種實(shí)現(xiàn)解決方案,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-08-08
  • Java構(gòu)造函數(shù)通透理解篇

    Java構(gòu)造函數(shù)通透理解篇

    這篇文章主要介紹了Java構(gòu)造函數(shù),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-09-09
  • 一文帶你深入了解Java8 Stream流式編程

    一文帶你深入了解Java8 Stream流式編程

    在實(shí)際項(xiàng)目當(dāng)中,若能熟練使用Java8 的Stream流特性進(jìn)行開發(fā),就比較容易寫出簡(jiǎn)潔優(yōu)雅的代碼。本文主要就是基于實(shí)際項(xiàng)目常用的Stream Api流式處理總結(jié),希望對(duì)大家有所幫助
    2023-04-04
  • Java中抽象類的作用及說明

    Java中抽象類的作用及說明

    這篇文章主要介紹了Java中抽象類的作用及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11

最新評(píng)論