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

java使用Dijkstra算法實現(xiàn)單源最短路徑

 更新時間:2019年01月21日 08:34:56   作者:貓小呆  
這篇文章主要為大家詳細介紹了java使用Dijkstra算法實現(xiàn)單源最短路徑,具有一定的參考價值,感興趣的小伙伴們可以參考一下

 單源最短路徑問題,即在圖中求出給定頂點到其它任一頂點的最短路徑。在弄清楚如何求算單源最短路徑問題之前,必須弄清楚最短路徑的最優(yōu)子結(jié)構(gòu)性質(zhì)。

一、最短路徑的最優(yōu)子結(jié)構(gòu)性質(zhì)

該性質(zhì)描述為:如果P(i,j)={Vi....Vk..Vs...Vj}是從頂點i到j(luò)的最短路徑,k和s是這條路徑上的中間頂點,那么P(k,s)必定是從k到s的最短路徑。下面證明該性質(zhì)的正確性。

假設(shè)P(i,j)={Vi....Vk..Vs...Vj}是從頂點i到j(luò)的最短路徑,則有P(i,j)=P(i,k)+P(k,s)+P(s,j)。而P(k,s)不是從k到s的最短距離,那么必定存在另一條從k到s的最短路徑P'(k,s),那么P'(i,j)=P(i,k)+P'(k,s)+P(s,j)<P(i,j)。則與P(i,j)是從i到j(luò)的最短路徑相矛盾。因此該性質(zhì)得證。

二、Dijkstra算法

Dijkstra提出按各頂點與源點v間的路徑長度的遞增次序,生成到各頂點的最短路徑的算法。既先求出長度最短的一條最短路徑,再參照它求出長度次短的一條最短路徑,依次類推,直到從源點v 到其它各頂點的最短路徑全部求出為止。 

對于下圖:


運行結(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

=====================================

public class Dijkstra {
 static int M=10000;//(此路不通)
 public static void main(String[] args) {
  // TODO Auto-generated method stub
  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 = Dijsktra(weight2,start);
  
  for(int i = 0;i < shortPath.length;i++)
    System.out.println("從"+start+"出發(fā)到"+i+"的最短距離為:"+shortPath[i]); 
   
 }
 
 
 public static int[] Dijsktra(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]; //標(biāo)記當(dāng)前該頂點的最短路徑是否已經(jīng)求出,1表示已求出
  
  //初始化,第一個頂點求出
  shortPath[start] = 0;
  visited[start] = 1;
 
  for(int count = 1;count <= n - 1;count++) //要加入n-1個頂點
  {
 
   int k = -1; //選出一個距離初始頂點start最近的未標(biāo)記頂點
   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;
    } 
     
   }
   System.out.println("k="+k);
    
   //將新選出的頂點標(biāo)記為已求出最短路徑,且到start的最短路徑就是dmin
   shortPath[k] = dmin;
 
   visited[k] = 1;
 
   //以k為中間點,修正從start到未訪問各點的距離
   for(int i = 0;i < n;i++)
   {     // System.out.println("k="+k);
    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;
 }
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Spring整合Junit詳解

    Spring整合Junit詳解

    Spring 是目前主流的 Java Web 開發(fā)框架,是 Java 世界最為成功的框架。該框架是一個輕量級的開源框架,具有很高的凝聚力和吸引力,本篇文章帶你了解如何配置數(shù)據(jù)源、注解開發(fā)以及整合Junit
    2022-07-07
  • springboot如何讀取配置文件(application.yml)中的屬性值

    springboot如何讀取配置文件(application.yml)中的屬性值

    本篇文章主要介紹了springboot如何讀取配置文件(application.yml)中的屬性值,具有一定的參考價值,有興趣的小伙伴可以了解一下
    2017-04-04
  • 一文詳解Java中Stream流的使用

    一文詳解Java中Stream流的使用

    JDK8新增了Stream(流操作)處理集合的數(shù)據(jù),可執(zhí)行查找、過濾和映射數(shù)據(jù)等操作.本文將通過一些實例介紹stream流的使用,需要的可以參考一下
    2022-05-05
  • 關(guān)于java中基本數(shù)據(jù)類型的數(shù)值范圍

    關(guān)于java中基本數(shù)據(jù)類型的數(shù)值范圍

    這篇文章主要介紹了關(guān)于java中基本數(shù)據(jù)類型的數(shù)值范圍,基本類型,或者叫做內(nèi)置類型,是JAVA中不同于類的特殊類型,它們是我們編程中使用最頻繁的類型,需要的朋友可以參考下
    2023-07-07
  • java分析html算法(java網(wǎng)頁蜘蛛算法示例)

    java分析html算法(java網(wǎng)頁蜘蛛算法示例)

    近來有些朋友在做蜘蛛算法,或者在網(wǎng)頁上面做深度的數(shù)據(jù)挖掘,下面使用示例
    2014-03-03
  • Java中的main方法調(diào)用非靜態(tài)方法處理

    Java中的main方法調(diào)用非靜態(tài)方法處理

    這篇文章主要介紹了Java中的main方法調(diào)用非靜態(tài)方法處理,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 淺談Java高并發(fā)解決方案以及高負(fù)載優(yōu)化方法

    淺談Java高并發(fā)解決方案以及高負(fù)載優(yōu)化方法

    這篇文章主要介紹了淺談Java高并發(fā)解決方案以及高負(fù)載優(yōu)化方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Java中的final關(guān)鍵字使用方式

    Java中的final關(guān)鍵字使用方式

    這篇文章主要介紹了Java中的final關(guān)鍵字使用方式,final 關(guān)鍵字用于修飾不可改變內(nèi)容,更多相關(guān)梳理總結(jié),需要的小伙伴可以參考下面文章內(nèi)容
    2022-06-06
  • Java創(chuàng)建,編輯與刪除Excel迷你圖表的實現(xiàn)方法

    Java創(chuàng)建,編輯與刪除Excel迷你圖表的實現(xiàn)方法

    迷你圖是Excel工作表單元格中表示數(shù)據(jù)的微型圖表。本文將通過Java代碼示例介紹如何在Excel中創(chuàng)建迷你圖表,以及編輯和刪除表格中的迷你圖表,需要的可以參考一下
    2022-05-05
  • SpringBoot訪問請求404解決方法

    SpringBoot訪問請求404解決方法

    這篇文章主要介紹了SpringBoot訪問請求404解決方法,文中有詳細的解決方法供大家參考,對我們學(xué)習(xí)或工作有一定的幫助,需要的朋友跟著小編一起來學(xué)習(xí)吧
    2023-07-07

最新評論