Fortran 板


LINE

首先非常感謝mantour大大的解釋: 另外在此鄭重的向mantour道個歉,當天投水球問問題時, 我的行為顯得突兀冒失...... 希望mantour大人大量不予計較。 最後提出我對這個演算法的發現與疑問, 當i,j,k任兩個為相同時,其路徑長 D(i,j) 不會產生任何改變, 所以可以跳過這些情況,不必去考慮! 雖然我現下瞭解這個演算法中,每個迴圈的作用為何, 但我很疑惑的是,為什麼最外層K的順序不影響最後之結果? 這演算法其先運算的結果可能會在後運算時再次的被拿來運用。 例如,依迴圈順序 (a).k=3,j=2,i=5的執行順序是在 (b).k=4,j=2,i=3之前, 假設(b)的情況是V3與V2之間可以透過V4來減少距離, 即 V3-><-V2 = inf 可由 V3-->V4-->V2 = 2 來取代。 但若(a)的情況是V5與V2之間無法透過V3來減少距離,且V5與V2之間無直接連結, 即 V5-><-V2 =inf 且(b)的情況仍未執行,所以 V3-><-V2 = inf , 在這樣的情形下,我們得到 V5-->V3-><-V2 = inf , 而非真實情況下的 V5-->V3-->V4-->V2 = 3 。 以上是我自以為合理的推演,看起來最外層K的執行順序會影響到最終的執行結果, 但我實際上操作的結果卻沒有這樣的發現,這中間是否還有什麼我沒弄懂的地方, 希望瞭解的大大可以為在下指點迷津! 謝謝各位! ※ 引述《mantour (朱子)》之銘言: : 這個問題是典型的dynamic programming的例子 : 基本上可以直接套用floyd最短路徑演算法 : 就演算法的精神說明一下 : 一開始用一個矩陣D表示節點的相鄰性 : D(i,i) = 0 : 若vi,vj之間有連結,則D(i,j)=1 : 若沒有連結 : D(i,j) = Inf (Inf 為自設的常數,比任二點可能的最大步數大) : 此時D(i,j)表示了vi,vj直接相連的步數 : 接著考慮從vi走到vj,中間可以經過v1的最少步數 : 如果經過v1的步數比本來直接走短,就把D(i,j)重設為新路徑的步數 : 也就是說對所有的i,j : if( D(i,1)+D(1,j) .lt. D(i,j)) then : D(i,j) = D(i,1) + D(1,j) : end if : 再來考慮vi,vj中間可經過v1,v2的最少步數 : 這裡有一點tricky的地方是,我們不需要真的去算所有經過v1或v2的組合 : 只要分成二點來考慮就可以了的大小就可以了 : 1) 由vi到vj 可經可不經v1 但 不經v2 也不經過其他點 的最小步數 : 2) 由vi到vj 可經可不經v1 但 必須經過 v2 不經過其他點 的最小步數 : 只要比較這二個數值中比較小的就是由vi到vj 可經可不經v1,v2 的最少步數 : 其中 1)前面已經算過了,就是 目前的D(i,j) : 而2)呢? 可以想一想,如果有一條最短的路線從 vi 經過 v2 到 vj : 中間可經可不經v1 但不可經過其他點 : 則其中由vi到v2和由v2到vj這二段分別一定也是走可經可不經v1 而不經其他點的最短路徑 : 也就是 2) = D(i,2) + D(2,j) : 因此假如對所有i,j再進行一次重設 : if( D(i,2)+D(2,j) .lt. D(i,j)) then : D(i,j) = D(i,2) + D(2,j) : end if : 就得到任二點之間 可經可不經 v1,v2 ,但不經其他點的最短步數 : 重複這個動作 : 就可以得到任二點之間,可經可不經其他所有點 的最短步數 : 也就是我們要的答案 : 整個演算法寫出來只需要三層迴圈 : do k=1,N : do j=1,N : do i=1,N : if (D(i,k)+D(k,j) .lt. D(i,j)) then : D(i,j) = D(i,k) + D(k,j) : end if : end do : end do : end do : 時間複雜度為O(N^3) : 其中由於連結沒有方向性,因此D是對稱的,實際上只需計算上三角的部份即可 : 所以還可以再修改節省一點時間 : 打了半天好像還是講得不是很清楚 : 不過只要把演算法的名字丟到google應該就可以找到更詳細的說明 : 希望對原PO有幫助 : 也希望我有寫錯的地方大家可以幫我指出來 : ※ 引述《yin0416 (冷色鉛筆)》之銘言: : : 假設有N個點,每個點相互之間有些有連結,有些沒有連結。 : : 給你一個N乘N的矩陣,代表每個點相互之間連結的有或無。 : : 請算出每個點與點之間的最小連結步數, : : 例如點1與點2有連結,點2與點3之間有連結,而點1與點3之間沒有直接連結, : : 則點1與點3之間的最小連結步數即為2步。 : : 老師並不要求我寫出來,所以我不是為了應付作業而來發問的。 : : 這個程式的結構我想了很久,但沒有想出來。 -- ◤◢ ▇▇ \ / \ ◣ \〝// ◤◥ !◤)◥◥! 〒 〒 ● ● lm ◢"" v "" ※╲ ψg80046 --



※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 140.128.128.158 ※ 編輯: yin0416 來自: 140.128.128.158 (12/08 11:45)
1F:推 mantour:考慮執行到 (c) k=4,j=2,i=5 時會發生什麼事? 12/08 14:23
2F:→ mantour:另外這個方法叫做動態規劃而不是遞迴 12/08 14:24
抱歉,原來我誤解了,已去掉那一句了!
3F:→ mantour:建議寫個程式把k=1~n的執行結果印出來研究研究 12/08 14:27
現在我正在人工觀察中,謝謝建議! ※ 編輯: yin0416 來自: 140.128.128.158 (12/08 15:13)







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:WOW站內搜尋

TOP