精華區beta ask-why 關於我們 聯絡資訊
看了原文書上對Warshall Algorithm的解釋 還是不太懂他的意思, 只知道這是用來算最短距離的 下面有練習題 Find the matrices W0 W1 W2 W3 and W4 The matrix W4 is the transtive closure of R W0 = (1,4) (2,1) (2,3) (3,1) (3,4) (4,3) ANS w1 = (1,4) (2,1) (2,3) (2,4) (3,1) (3,4) (4,3) w2 = w1 w3 = (1,4) (2,1) (2,3) (2,4) (3,1) (3,4) (4,1) (4,3) (4,4) w4 = (1,4) (2,1) (2,3) (2,4) (3,1) (3,3) (3,4) (4,1) (4,3) (4,4) (原圖片是Matrix 抱歉小弟不會用PTT畫圖) 可以請高手大大用這題來解釋一下他是怎麼算出來的嗎? 感激不盡! -- 表氏宗親家族聚會 ◢██ ◣ ◢███◣◢███◣◢███◣◢███◣◢███◣ ██◥◥ 其他人呢? ◢表哥 █◢大表弟█◢二表弟█◢三表弟█◢四表弟█ █ ● ● ◢ ▂ ▂ ▕▂ ▂ ▕▂ ▂ ▕▂ ▂ ▕▂ ▂ ▕ █◥ ︶◢ 還在歐兔相認中 — — ⊙⊙ - - ^ ^ * * ◢ ◥◢ ◣ ▋ ▋ ▋ ▋ 皿 ▋ -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 70.42.120.240 > -------------------------------------------------------------------------- < 作者: stimim (qqaa) 看板: ask-why 標題: Re: [請益] Warshall algorithm 時間: Mon Jun 8 21:47:00 2009 ※ 引述《yueimasaka2 (垂哥)》之銘言: : 看了原文書上對Warshall Algorithm的解釋 還是不太懂他的意思, : 只知道這是用來算最短距離的 : 下面有練習題 : Find the matrices W0 W1 W2 W3 and W4 : The matrix W4 is the transtive closure of R : W0 = (1,4) (2,1) (2,3) (3,1) (3,4) (4,3) : ANS w1 = (1,4) (2,1) (2,3) (2,4) (3,1) (3,4) (4,3) : w2 = w1 : w3 = (1,4) (2,1) (2,3) (2,4) (3,1) (3,4) (4,1) (4,3) (4,4) : w4 = (1,4) (2,1) (2,3) (2,4) (3,1) (3,3) (3,4) (4,1) (4,3) (4,4) : (原圖片是Matrix 抱歉小弟不會用PTT畫圖) : 可以請高手大大用這題來解釋一下他是怎麼算出來的嗎? : 感激不盡! ================================================================ Procedure FloydWarshall() for k := 1 to n for i := 1 to n for j := 1 to n dis[i][j] := min( dis[i][j] , dis[i][k]+dis[k][j] ); ================================================================ 以上為FloydWarshall的虛擬碼 而你的題目所用到的是Floyd-Warshall Algorithm的簡化形式, 單純判斷 (i,j) 是否相連 W0:  ┌─┬─┬─┬─┬─┐  │\│1│2│3│4│ k = 1 ,現在考慮還不相連的Case (i,j),  ├─┼─┼─┼─┼─┤  │1│ │ │ │O│ 如果 (i,k) == O 且 (k,j) == O 則 (i,j) := O  ├─┼─┼─┼─┼─┤  │2│O│ │O│ │ Ex: (2,1) == O 且 (1,4) == O -> (2,4) := O  ├─┼─┼─┼─┼─┤  │3│O│ │ │O│ 滿足條件的(i,j): { (2,4) }  ├─┼─┼─┼─┼─┤  │4│ │ │O│ │  └─┴─┴─┴─┴─┘ W1: ※紅色代表新增的路徑 ┌─┬─┬─┬─┬─┐  │\│1│2│3│4│ k = 2 ,一樣考慮還不相連的Case  ├─┼─┼─┼─┼─┤  │1│ │ │ │O│ if ((i,k) == O and (k,j) == O) then (i,j) := O  ├─┼─┼─┼─┼─┤  │2│O│ │O││ 滿足條件的(i,j):ψ  ├─┼─┼─┼─┼─┤  │3│O│ │ │O│  ├─┼─┼─┼─┼─┤  │4│ │ │O│ │  └─┴─┴─┴─┴─┘ W2: ┌─┬─┬─┬─┬─┐  │\│1│2│3│4│ k = 3  ├─┼─┼─┼─┼─┤  │1│ │ │ │O│ 滿足條件的(i,j): { (4,1) , (4,4) }  ├─┼─┼─┼─┼─┤  │2│O│ │O│O│  ├─┼─┼─┼─┼─┤  │3│O│ │ │O│  ├─┼─┼─┼─┼─┤  │4│ │ │O│ │  └─┴─┴─┴─┴─┘ W3: ┌─┬─┬─┬─┬─┐  │\│1│2│3│4│ k = 4  ├─┼─┼─┼─┼─┤  │1│ │ │ │O│ 滿足條件的(i,j): { (3,3) }  ├─┼─┼─┼─┼─┤  │2│O│ │O│O│  ├─┼─┼─┼─┼─┤  │3│O│ │ │O│  ├─┼─┼─┼─┼─┤  │4││ │O││  └─┴─┴─┴─┴─┘ W4 ┌─┬─┬─┬─┬─┐  │\│1│2│3│4│ Done~  ├─┼─┼─┼─┼─┤  │1│ │ │ │O│  ├─┼─┼─┼─┼─┤  │2│O│ │O│O│  ├─┼─┼─┼─┼─┤  │3│O│ ││O│  ├─┼─┼─┼─┼─┤  │4│O│ │O│O│  └─┴─┴─┴─┴─┘ ================================================= Floyd-Warshall Algorithm其實是用到DP的概念, 假設 D[k][i][j]代表的是,由 i 走到 j , 路途中只經過編號不大於k的點,所能得到的最小值 => D[k][i][j] = min( D[k-1][i][j] , D[k-1][i][k]+D[k-1][k][j] ) 如此一來,當D[][][]全部被填完之後,D[n][i][j]存的就是 i 到 j 的最短路徑長 為什麼呢? 假設從i走到j必須要經過某些點,這些點中最大的編號為 k_m 也就是 D[n][i][j] = D[n-1][i][j] = D[n-2][i][j] = ... = D[k_m][i][j] 且 D[k_m][i][j] = D[n][i][k_m] + D[n][k_m][j] 現在考慮 i 到 k_m 的距離 i 到 k_m 的最短路徑一定不需要經過 編號大於等於 k_m 的點 於是就有: D[n][i][k_m] = D[n-1][i][k_m] = ... = D[k_m-1][i][k_m] 同理,故 D[k_m][i][j] = D[k_m-1][i][k_m] + D[k_m-1][k_m][j] 以上是說明法, 如果要證明的話可以用歸納法, 假設D[k][i][j] 對所有的 (i,j) 都存有 經過編號不大於k的點所能產生的最短路徑 再證明 D[k+1][i][j] 也有同樣的性質 而初始條件是: D[0][i][j] 代表不經過任何點,直接從i走到j的路徑長 我想應該就滿完整了 -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 61.228.153.124
micklin:推 06/09 23:37