亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

基于Java實現(xiàn)的Dijkstra算法示例

 更新時間:2014年07月24日 09:13:51   投稿:shichen2014  
這篇文章主要介紹了基于Java實現(xiàn)的Dijkstra算法示例,一個比較典型的算法示例,需要的朋友可以參考下

本文以實例形式介紹了基于Java實現(xiàn)的Dijkstra算法,相信對于讀者研究學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)域算法有一定的幫助。

Dijkstra提出按各頂點與源點v間的路徑長度的遞增次序,生成到各頂點的最短路徑的算法。即先求出長度最短的一條最短路徑,再參照它求出長度次短的一條最短路徑,依次類推,直到從源點v 到其它各頂點的最短路徑全部求出為止。
其代碼實現(xiàn)如下所示:

package com.algorithm.impl;

public class Dijkstra {
 private static int M = 10000; //此路不通
 public static void main(String[] args) {
 int[][] weight1 = {//鄰接矩陣 
        {0,3,2000,7,M}, 
        {3,0,4,2,M}, 
        {M,4,0,5,4}, 
        {7,2,5,0,6},   
        {M,M,4,6,0} 
    }; 

    int[][] weight2 = { 
        {0,10,M,30,100}, 
        {M,0,50,M,M}, 
        {M,M,0,M,10}, 
        {M,M,20,0,60}, 
        {M,M,M,M,0} 
    };
    
    int start=0; 
    int[] shortPath = dijkstra(weight2,start); 
     
    for(int i = 0;i < shortPath.length;i++) 
       System.out.println("從"+start+"出發(fā)到"+i+"的最短距離為:"+shortPath[i]); 
 }
 
 public static int[] dijkstra(int[][] weight, int start) {
 //接受一個有向圖的權(quán)重矩陣,和一個起點編號start(從0編號,頂點存在數(shù)組中) 
    //返回一個int[] 數(shù)組,表示從start到它的最短路徑長度 
 int n = weight.length;      //頂點個數(shù)
 int[] shortPath = new int[n];  //保存start到其他各點的最短路徑
 String[] path = new String[n];  //保存start到其他各點最短路徑的字符串表示
 for(int i=0;i<n;i++) 
  path[i]=new String(start+"-->"+i); 
 int[] visited = new int[n];   //標記當前該頂點的最短路徑是否已經(jīng)求出,1表示已求出 
 
 //初始化,第一個頂點已經(jīng)求出
 shortPath[start] = 0;
 visited[start] = 1;
 
 for(int count = 1; count < n; count++) {   //要加入n-1個頂點
  int k = -1;        //選出一個距離初始頂點start最近的未標記頂點 
  int dmin = Integer.MAX_VALUE;
  for(int i = 0; i < n; i++) {
  if(visited[i] == 0 && weight[start][i] < dmin) {
   dmin = weight[start][i];
   k = i;
  }
  }
  
  //將新選出的頂點標記為已求出最短路徑,且到start的最短路徑就是dmin 
  shortPath[k] = dmin;
  visited[k] = 1;
  
  //以k為中間點,修正從start到未訪問各點的距離 
  for(int i = 0; i < n; i++) {
  if(visited[i] == 0 && weight[start][k] + weight[k][i] < weight[start][i]) {
   weight[start][i] = weight[start][k] + weight[k][i];
   path[i] = path[k] + "-->" + i; 
  }
  }
 }
 for(int i = 0; i < n; i++) {
  System.out.println("從"+start+"出發(fā)到"+i+"的最短路徑為:"+path[i]);
 }
 System.out.println("====================================="); 
 return shortPath;
 }
}

該程序運行結(jié)果為:

從0出發(fā)到0的最短路徑為:0-->0
從0出發(fā)到1的最短路徑為:0-->1
從0出發(fā)到2的最短路徑為:0-->3-->2
從0出發(fā)到3的最短路徑為:0-->3
從0出發(fā)到4的最短路徑為:0-->3-->2-->4
=====================================
從0出發(fā)到0的最短距離為:0
從0出發(fā)到1的最短距離為:10
從0出發(fā)到2的最短距離為:50
從0出發(fā)到3的最短距離為:30
從0出發(fā)到4的最短距離為:60

相關(guān)文章

  • springboot3解決跨域的幾種方式小結(jié)

    springboot3解決跨域的幾種方式小結(jié)

    這篇文章主要介紹了springboot3解決跨域的幾種方式,文中通過代碼示例給大家介紹的非常詳細,對大家的解決跨域有一定的幫助,需要的朋友可以參考下
    2024-03-03
  • Java在web頁面上的編碼解碼處理及中文URL亂碼解決

    Java在web頁面上的編碼解碼處理及中文URL亂碼解決

    這篇文章主要介紹了Java在web頁面上的編碼解碼處理及中文URL亂碼解決,文中所介紹的兩種使用過濾器解決中文鏈接亂碼的方法非常有效,需要的朋友可以參考下
    2016-02-02
  • SpringBoot集成Swagger3的實現(xiàn)

    SpringBoot集成Swagger3的實現(xiàn)

    本文主要介紹了SpringBoot集成Swagger3的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • Mybatis-Plus 全局配置無效的解決方案

    Mybatis-Plus 全局配置無效的解決方案

    這篇文章主要介紹了Mybatis-Plus 全局配置無效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • Java 控制線程的方法

    Java 控制線程的方法

    這篇文章主要介紹了Java 控制線程的方法,文中講解非常細致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-06-06
  • mall整合SpringSecurity及JWT認證授權(quán)實戰(zhàn)下

    mall整合SpringSecurity及JWT認證授權(quán)實戰(zhàn)下

    這篇文章主要為大家介紹了mall整合SpringSecurity及JWT認證授權(quán)實戰(zhàn)第二篇,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • 詳解SpringBoot實現(xiàn)ApplicationEvent事件的監(jiān)聽與發(fā)布

    詳解SpringBoot實現(xiàn)ApplicationEvent事件的監(jiān)聽與發(fā)布

    這篇文章主要為大家詳細介紹了SpringBoot如何實現(xiàn)ApplicationEvent事件的監(jiān)聽與發(fā)布,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-03-03
  • 使用springmvc運行流程分析,手寫spring框架嘗試

    使用springmvc運行流程分析,手寫spring框架嘗試

    這篇文章主要介紹了使用springmvc運行流程分析,手寫spring框架嘗試,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • SpringBoot?使用?Sa-Token?完成注解鑒權(quán)功能(權(quán)限校驗)

    SpringBoot?使用?Sa-Token?完成注解鑒權(quán)功能(權(quán)限校驗)

    Sa-Token?是一個輕量級?java?權(quán)限認證框架,主要解決登錄認證、權(quán)限認證、單點登錄、OAuth2、微服務(wù)網(wǎng)關(guān)鑒權(quán)?等一系列權(quán)限相關(guān)問題,這篇文章主要介紹了SpringBoot使用Sa-Token完成注解鑒權(quán)功能,需要的朋友可以參考下
    2023-05-05
  • Java操作Excel的示例詳解

    Java操作Excel的示例詳解

    在平時可以使用IO流對Excle進行操作,但是現(xiàn)在使用更加方便的第三方組件來實現(xiàn)。本文就來和大家聊聊Java如何通過第三方組件實現(xiàn)操作Excel,需要的可以參考一下
    2023-01-01

最新評論