• <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>
            xiaoguozi's Blog
            Pay it forword - 我并不覺的自豪,我所嘗試的事情都失敗了······習慣原本生活的人不容易改變,就算現狀很糟,他們也很難改變,在過程中,他們還是放棄了······他們一放棄,大家就都是輸家······讓愛傳出去,很困難,也無法預料,人們需要更細心的觀察別人,要隨時注意才能保護別人,因為他們未必知道自己要什么·····
            最小費用最大流 修改的dijkstra + Ford-Fulksonff算法
            修改的dijkstra其實和Johnson算法的思想是一致的。
             
            一個求最小費用最大流的樸素算法是這樣的:
            1 求最小費用增廣路
            2 判斷是否存在增廣路,否的話算法終止。
            3 增加增廣路上邊的流量
            4 在增廣路上添加必要的逆向負權邊
            5 goto 1
             
            因為負權邊的存在,求最小費用增廣路就不可以用dijkstra算法。當然,我們可以用bellman
            -ford算法,可是這樣的話求一次最短路的時間代價就是O(e*n),e是邊數,n是頂點數。代價大了點,如果能用dijkstra算法就好了。利用Johnson算法的思想,這是可以做到的。
             
            第一次求最短路可以用dijkstra算法(如果一開始就有負權邊,那就用bellman
            -ford算法,這沒關系),求出源點到所有點的距離,嗯,我說的距離是指路徑上邊的費用之和的最小值。注意,要求出到所有點的距離,而不是求出到匯點的距離就完事了。
            假設有一條邊u
            ->v,源點到u的距離是d[u],到v的距離是d[v],邊的費用(權值)是w(u,v)。很顯然,d[u]+w(u,v)>=d[v],不然的話,你會發(fā)現一條更好的路徑從源點到v。問題是,什么時候取等呢?當u->v在v的最優(yōu)路徑上,范圍說小一點,當u->v在從源點到匯點的最優(yōu)路徑,即最小費用增廣路上。
            好的,如果u
            ->v被你增載了,你要開始添負權邊v->u了,權值取負,就是-w(u,v)。負權就是討厭,是正的就好了,dijkstra算法就可以再用了。怎么辦呢,把負權邊加個權值,讓它非負。要加多少呢,d[v]-d[u]。當然不能只加一條邊,對所有邊,無論原有的還是新添的,按這個規(guī)則加,構造一個新的圖:
                            對邊a
            ->b,新的邊權w'(a,b)=w(a,b)+d[a]-d[b]
            現在來看看你的杰作:
                            對原來的邊u
            ->v, w'(u,v)=w(u,v)+d[u]-d[v]: 記得么d[u]+w(u,v)>=d[v], 所以 w'(u,v) >= 0
                            對新加的負權邊v
            ->u, w'(v,u)=w(v,u)+d[v]-d[u]=-w(u,v)+d[v]-d[u]: 記得么d[u]+w(u,v)==d[v],這里可是取等號的,所以w'(v,u) == 0
            哈哈,這下所有邊又是非負的了。
            可是,問題是,為啥不每個邊加個足夠大的正數,這樣不是所有邊也都是正的了么。仔細想想,邊權為啥要為正,不就是為了求源點到匯點的最短路方便么,可是,都加大正數的話,你求出的最短路和原來圖的最短路能一致么,不能,為啥,畫個三角形,自己想想。可是,我的方法就能一致么,能。我證明給你看。
             
            假設從源點s到匯點t有一條路徑s
            ->a->b->c->d.->t,在原圖中的路徑長度為
                             w(s,a)
            +w(a,b)+w(b,c)++w(x,t)
            在新圖中的路徑為
                             w
            '(s,a)+w'(a,b)+w'(b,c)+w'(x,t)
            展開來就是
                             w(s,a)
            +d[a]-d[s]+w(a,b)+d[b]-d[a]+w(c,d)+d[d]-d[b]+.+w(x,t)+d[t]-d[x]
            消阿消,d[a]和
            -d[a],d[b]和-d[b]d[x]和-d[x],剩下什么呢:
                             w(s,a)
            +w(a,b)+w(b,c)++w(x,t)+d[t]-d[s]
            噢,不就比原圖中多d[t]
            -d[s]么(其實d[s]==0)。這可是對所有s到t的路徑都成立的,既然所有路徑,在新圖中的權值都比在原圖中的權值多了d[t],那么,新圖的最短路,也就對應原圖的最短路,只不過路徑長度多了d[t],這不僅對t成立,對所有節(jié)點u都成立,只不過新圖中到u的最短路長度比原圖多了d[u]。
             
            好,用dijkstra算法,第二次求出最短路。然后求出新的d’[u],然后添加新的邊,然后準備第三次的dijkstra算法。。。為什么第二次可以這樣做,第三次還可以這樣做,第三次的原圖可能有很多負權邊啊?我可沒說過w(u,v)
            >=0這樣的限制,所以,即使原圖有負權邊還是可以這樣做的。
             
            好了,第一次dijkstra算法(或者bellman
            -ford算法,如果有負權邊的話,只用一次,不會成為瓶頸的),然后每次求最小增廣路用一次修改的dijkstra算法。這個算法求最小費用最大流復雜度是O(m*n*n), m是最大流量,或者是求增廣路次數的上界。最后,如果用這個算法來求最優(yōu)匹配問題,復雜度是O(n^3)的。
            posted on 2008-08-03 20:49 小果子 閱讀(5117) 評論(9)  編輯 收藏 引用

            FeedBack:
            # re: 最小費用最大流
            2008-08-30 12:24 | newmyl
            最小費用最大流,我用Dijkstra過poj2516最后是900多ms,但我用Spfa過這題,我只用了700多ms,  回復  更多評論
              
            # re: 最小費用最大流
            2009-09-27 20:19 | SwordHoly
            大牛能給個代碼嗎,我郵箱jiangmingh@126.com,萬分感謝,自己寫的實在是頭大了,因為d值一直要變,不知道結果怎么算了  回復  更多評論
              
            # re: 最小費用最大流
            2009-11-12 09:51 | janlim
            你好,能給個程序嗎?我的郵箱是linjunemail@163.com,和輸入的格式。。先謝謝了、、  回復  更多評論
              
            # re: 最小費用最大流
            2010-03-08 10:06 | nuanbaby
            你好,能同樣發(fā)我個程序和輸入的格式嗎?我的郵箱是wszbd_lz@126.com~~~

            謝謝啦~~~  回復  更多評論
              
            # re: 最小費用最大流[未登錄]
            2010-12-07 20:54 | along
            大哥講得很具體嘛,贊一個  回復  更多評論
              
            # re: 最小費用最大流
            2012-03-08 18:15 | 曠志鑫
            第一次就有負邊,好像一定要用bellman-ford求出距離,  回復  更多評論
              
            # re: 最小費用最大流
            2012-03-08 18:16 | 曠志鑫
            可以把原先的先保存起來,以后就不用變了  回復  更多評論
              
            # re: 最小費用最大流
            2012-04-04 11:51 | xw
            謝謝!  回復  更多評論
              
            # re: 最小費用最大流
            2015-02-20 21:42 | Spfa
            能不能發(fā)個代碼呢>>最好是Fibonacci堆優(yōu)化的Dijkstra
            C++ 的
            謝謝!  回復  更多評論
              
            久久精品国产99国产精品| 久久精品视频网| 亚洲精品无码久久一线| 久久99国产综合精品女同| 久久精品国产欧美日韩| 精品久久久无码21p发布| 66精品综合久久久久久久| 亚洲欧洲久久久精品| 99久久无码一区人妻a黑| 无夜精品久久久久久| 久久久国产精品福利免费 | 青青草原综合久久大伊人精品| 久久精品国产亚洲Aⅴ香蕉| 欧美亚洲色综久久精品国产| 久久精品国产亚洲5555| 成人妇女免费播放久久久| 波多野结衣久久精品| 久久精品中文字幕一区| 国内精品久久久久久99| 伊人久久大香线蕉综合5g| 国产 亚洲 欧美 另类 久久| 久久亚洲AV成人无码国产 | 久久亚洲国产最新网站| 热久久这里只有精品| 国产精品无码久久综合| 亚洲精品乱码久久久久久按摩 | 久久久久久午夜精品| 国产精品嫩草影院久久| 久久被窝电影亚洲爽爽爽| 奇米影视7777久久精品| 国产精品一区二区久久精品涩爱| 精品人妻伦九区久久AAA片69| 国产精品久久久久影视不卡| 狠狠综合久久综合88亚洲| 久久青青草视频| 久久亚洲精品无码aⅴ大香| 久久伊人影视| 亚洲午夜无码AV毛片久久| 一97日本道伊人久久综合影院| 99热精品久久只有精品| 久久av高潮av无码av喷吹|