Fortran 板


LINE

這個問題是典型的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步。 : 老師並不要求我寫出來,所以我不是為了應付作業而來發問的。 : 這個程式的結構我想了很久,但沒有想出來。 --



※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 140.112.213.158
1F:推 YCTzeng:寫的很好,雖然我沒用到,但又學到一招,感謝。 11/09 21:10
2F:推 yin0416:謝了!只要三個迴圈!太帥了! 11/10 00:24
3F:推 yin0416:這個程式我已經會使用了,但我只約略看懂它的意思,請問~ 11/24 17:05
4F:→ yin0416:這個程式能記錄最小路徑所經過的所有「點」嗎? 11/24 17:07
5F:推 yin0416:跟原PO說聲抱歉,我上次丟水球很突兀,也很沒禮貌! 11/30 10:16







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燈, 水草

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

TOP