国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設計 > 正文

算法訓練 最短路

2019-11-14 09:50:44
字體:
供稿:網(wǎng)友

問題描述 給定一個n個頂點,m條邊的有向圖(其中某些邊權可能為負,但保證沒有負環(huán))。請你計算從1號點到其他點的最短路(頂點從1到n編號)。

輸入格式 第一行兩個整數(shù)n, m。

接下來的m行,每行有三個整數(shù)u, v, l,表示u到v有一條長度為l的邊。

輸出格式 共n-1行,第i行表示1號點到i+1號點的最短路。 樣例輸入 3 3 1 2 -1 2 3 -1 3 1 2 樣例輸出 -1 -2 數(shù)據(jù)規(guī)模與約定 對于10%的數(shù)據(jù),n = 2,m = 2。

對于30%的數(shù)據(jù),n <= 5,m <= 10。

對于100%的數(shù)據(jù),1 <= n <= 20000,1 <= m <= 200000,-10000 <= l <= 10000,保證從任意頂點都能到達其他所有頂點。

package 最短路;import java.util.ArrayList;import java.util.Scanner;class Node { int now; int len; public Node(int now, int len) { super(); this.now = now; this.len = len; }}class LinkedArr{ ArrayList<Node> arr = new ArrayList<Node>();}public class Main { public static void main(String[] args) { // TODO Auto-generated method stub Scanner in = new Scanner(System.in); int n = in.nextInt(); //頂點數(shù) int m = in.nextInt(); //邊數(shù) LinkedArr[] arr = new LinkedArr[n+1]; int[] visit = new int[n+1]; int[] dist = new int[n+1]; for ( int i = 1 ; i <= n ; i++){ arr[i] = new LinkedArr(); dist[i] = Integer.MAX_VALUE; } while(m--!=0){ arr[in.nextInt()].arr.add(new Node(in.nextInt(), in.nextInt())); } for ( Node tmp : arr[1].arr){ dist[tmp.now] = tmp.len; } visit[1] = 1; for ( int i = 1 ; i < n ; i++){ int min = Integer.MAX_VALUE; int minj = Integer.MAX_VALUE; for ( int j = 2 ; j <= n ; j++){ if ( visit[j] == 0 && dist[j] < min){ min = dist[j]; minj = j; } } visit[minj] = 1; for ( Node tmp : arr[minj].arr){ if ( dist[minj] + tmp.len <= dist[tmp.now]){ dist[tmp.now] = dist[minj] + tmp.len; } } } for ( int i = 2 ; i <= n ; i++){ System.out.PRintln(dist[i]); } in.close(); }}

這里寫圖片描述 (PS:數(shù)據(jù)量大,所以Java超時了。。。)


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 眉山市| 宝应县| 丰台区| 林周县| 无锡市| 盐城市| 辽源市| 长宁县| 闸北区| 绵竹市| 贡山| 徐州市| 桐柏县| 沅陵县| 阿坝县| 衡阳县| 尼勒克县| 屏东市| 西城区| 自贡市| 武川县| 温泉县| 潼南县| 东台市| 樟树市| 简阳市| 怀来县| 翁牛特旗| 明光市| 广宁县| 微山县| 浦东新区| 红桥区| 尼勒克县| 垫江县| 宿松县| 泰州市| 政和县| 双柏县| 苏尼特左旗| 石首市|