• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            糯米

            TI DaVinci, gstreamer, ffmpeg
            隨筆 - 167, 文章 - 0, 評論 - 47, 引用 - 0
            數據加載中……

            [轉] Floyd 算法原理

                floyd算法是一個經典的動態規劃算法。用通俗的語言來描述的話,首先我們的目標是尋找從點i到點j的最短路徑。從動態規劃的角度看問題,我們需要為這個目標重新做一個詮釋(這個詮釋正是動態規劃最富創造力的精華所在),floyd算法加入了這個概念

                Ak(i,j):表示從i到j中途不經過索引比k大的點的最短路徑

                這個限制的重要之處在于,它將最短路徑的概念做了限制,使得該限制有機會滿足迭代關系,這個迭代關系就在于研究:假設Ak(i,j)已知,是否可以借此推導出Ak-1(i,j)。

                假設我現在要得到Ak(i,j),而此時Ak(i,j)已知,那么我可以分兩種情況來看待問題:1. Ak(i,j)沿途經過點k;2. Ak(i,j)不經過點k。如果經過點k,那么很顯然,Ak(i,j) = Ak-1(i,k) + Ak-1(k,j),為什么是Ak-1呢?因為對(i,k)和(k,j),由于k本身就是源點(或者說終點),加上我們求的是Ak(i,j),所以滿足不經過比k大的點的條件限制,且已經不會經過點k,故得出了Ak-1這個值。那么遇到第二種情況,Ak(i,j)不經過點k時,由于沒有經過點k,所以根據概念,可以得出Ak(i,j)=Ak-1(i,j)?,F在,我們確信有且只有這兩種情況---不是經過點k,就是不經過點k,沒有第三種情況了,條件很完整,那么是選擇哪一個呢?很簡單,求的是最短路徑,當然是哪個最短,求取哪個,故得出式子:

                Ak(i,j) = min( Ak-1(i,j), Ak-1(i,k) + Ak-1(k,j) )


            因此floyd的最外層循環:
            for (k = 0; k < n; k++) ...
            就是分別求出 A0(i,j), A1(i,j), ..., An(i,j)
            我屢次寫錯floyd的程序,今天又寫錯一次。。盡管它很短,但原理真的很牛比。
            只要知道了原理,就不會再寫錯了!

            posted on 2011-01-15 10:56 糯米 閱讀(5081) 評論(0)  編輯 收藏 引用 所屬分類: POJ 、Algorithm

            日批日出水久久亚洲精品tv| 久久精品亚洲中文字幕无码麻豆| 91精品国产色综久久| 日本精品久久久久中文字幕8| 四虎影视久久久免费观看| 久久精品国产亚洲Aⅴ蜜臀色欲| 久久精品这里热有精品| 久久精品一区二区三区AV| 久久亚洲国产精品五月天婷| 久久Av无码精品人妻系列 | 久久夜色撩人精品国产| 一本大道久久东京热无码AV| 手机看片久久高清国产日韩 | 狠狠色丁香婷婷综合久久来| 久久精品一区二区三区中文字幕| 99热成人精品免费久久| 国产色综合久久无码有码| 日韩人妻无码精品久久免费一| 精品国产乱码久久久久软件| 久久高潮一级毛片免费| 91精品婷婷国产综合久久| 久久久久99这里有精品10| 老色鬼久久亚洲AV综合| 漂亮人妻被中出中文字幕久久 | 无码精品久久久天天影视 | 国内精品久久久久久久影视麻豆 | 国产精品久久久久久久久软件 | 久久一日本道色综合久久| 性做久久久久久久久| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 一本久久a久久精品亚洲| 久久婷婷是五月综合色狠狠| 久久亚洲精品国产精品| 欧洲人妻丰满av无码久久不卡| 欧洲成人午夜精品无码区久久| 国产精品伦理久久久久久 | 国产99精品久久| 久久久亚洲AV波多野结衣| 四虎国产精品免费久久5151| 久久av无码专区亚洲av桃花岛| 无码国内精品久久人妻蜜桃|