青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

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],不然的話,你會發現一條更好的路徑從源點到v。問題是,什么時候取等呢?當u->v在v的最優路徑上,范圍說小一點,當u->v在從源點到匯點的最優路徑,即最小費用增廣路上。
好的,如果u
->v被你增載了,你要開始添負權邊v->u了,權值取負,就是-w(u,v)。負權就是討厭,是正的就好了,dijkstra算法就可以再用了。怎么辦呢,把負權邊加個權值,讓它非負。要加多少呢,d[v]-d[u]。當然不能只加一條邊,對所有邊,無論原有的還是新添的,按這個規則加,構造一個新的圖:
                對邊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成立,對所有節點u都成立,只不過新圖中到u的最短路長度比原圖多了d[u]。
 
好,用dijkstra算法,第二次求出最短路。然后求出新的d’[u],然后添加新的邊,然后準備第三次的dijkstra算法。。。為什么第二次可以這樣做,第三次還可以這樣做,第三次的原圖可能有很多負權邊啊?我可沒說過w(u,v)
>=0這樣的限制,所以,即使原圖有負權邊還是可以這樣做的。
 
好了,第一次dijkstra算法(或者bellman
-ford算法,如果有負權邊的話,只用一次,不會成為瓶頸的),然后每次求最小增廣路用一次修改的dijkstra算法。這個算法求最小費用最大流復雜度是O(m*n*n), m是最大流量,或者是求增廣路次數的上界。最后,如果用這個算法來求最優匹配問題,復雜度是O(n^3)的。
posted on 2008-08-03 20:49 小果子 閱讀(5153) 評論(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
你好,能同樣發我個程序和輸入的格式嗎?我的郵箱是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
能不能發個代碼呢>>最好是Fibonacci堆優化的Dijkstra
C++ 的
謝謝!  回復  更多評論
  

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产婷婷综合在线精品 | 99精品欧美一区二区三区| 久久精品国产一区二区三| 国产午夜精品视频| 久久成人18免费网站| 午夜精品一区二区三区四区| 国产视频在线观看一区二区| 久久亚洲国产精品一区二区 | 亚洲成色www8888| 日韩写真在线| 国产精品大片| 亚洲免费成人| 亚洲午夜极品| 亚洲第一精品电影| 亚洲美女视频| 国产亚洲精品自拍| 亚洲电影免费| 国产精品美女www爽爽爽| 久久久久9999亚洲精品| 免费不卡在线视频| 午夜精品福利电影| 美女精品视频一区| 亚洲欧美日本精品| 久色成人在线| 午夜精品久久久久久99热软件| 久久精品国产99精品国产亚洲性色 | 久久久久国产精品一区三寸| 免费亚洲电影在线| 先锋影院在线亚洲| 在线综合亚洲欧美在线视频| 激情另类综合| 一个色综合av| 亚洲国产专区| 久久狠狠一本精品综合网| 一区二区三区波多野结衣在线观看| 欧美一区二区私人影院日本| 在线综合+亚洲+欧美中文字幕| 亚洲欧美日韩在线不卡| 日韩亚洲国产精品| 久久久国产视频91| 欧美一区二区三区婷婷月色 | 久久久久国色av免费观看性色| 国产毛片一区二区| 亚洲欧洲另类国产综合| 国产一区观看| 亚洲欧美电影在线观看| 亚洲视频欧美在线| 欧美成人久久| 欧美成人综合网站| 韩国av一区二区三区| 亚洲网在线观看| 一本色道久久综合狠狠躁篇怎么玩| 久久久五月婷婷| 欧美中文字幕在线观看| 国产精品免费小视频| 日韩亚洲一区在线播放| 99精品免费| 欧美日韩18| 91久久国产综合久久| 亚洲高清视频在线观看| 久久久精品网| 久热精品视频| 在线精品国产成人综合| 久久精品日产第一区二区| 欧美在线免费观看视频| 国产精品专区h在线观看| 亚洲一区二区三区免费在线观看| 亚洲一区二区网站| 国产精品porn| 亚洲自拍偷拍网址| 香蕉成人啪国产精品视频综合网| 国产精品青草久久久久福利99| 亚洲视频播放| 欧美一区国产二区| 韩国女主播一区| 久久久国产成人精品| 欧美国产精品日韩| 一区二区三区波多野结衣在线观看| 欧美交受高潮1| 亚洲美女中文字幕| 小黄鸭精品密入口导航| 国产午夜亚洲精品理论片色戒| 久久精品成人| 欧美激情中文字幕在线| 一区二区黄色| 国产精品亚洲一区二区三区在线| 性做久久久久久久免费看| 六月丁香综合| 日韩亚洲视频在线| 国产麻豆综合| 快射av在线播放一区| 亚洲毛片av在线| 欧美一区二区黄| 亚洲国产精品久久| 欧美亚日韩国产aⅴ精品中极品| 午夜欧美不卡精品aaaaa| 美乳少妇欧美精品| 亚洲天堂久久| 极品尤物久久久av免费看| 欧美国产先锋| 性欧美videos另类喷潮| 欧美激情在线有限公司| 亚洲欧美综合另类中字| 亚洲国产高清自拍| 国产精品外国| 毛片一区二区| 亚洲免费人成在线视频观看| 欧美激情中文字幕乱码免费| 亚洲综合视频一区| 亚洲日本黄色| 国产午夜精品理论片a级探花| 欧美fxxxxxx另类| 午夜在线a亚洲v天堂网2018| 亚洲激情影视| 欧美fxxxxxx另类| 香蕉久久久久久久av网站 | 欧美色区777第一页| 久久成人综合视频| 一区二区三区三区在线| 亚洲国产精品激情在线观看| 久久国产综合精品| 一区二区三区欧美在线| 亚洲第一搞黄网站| 国产欧美日韩麻豆91| 欧美日韩国产小视频在线观看| 久久人人九九| 欧美一区二区在线观看| 亚洲天堂成人在线视频| 亚洲精品乱码| 亚洲国产日韩一区二区| 久久在线精品| 久久蜜桃精品| 久久精彩视频| 小黄鸭视频精品导航| 亚洲欧美日韩国产另类专区| 一本色道久久综合亚洲精品不卡| 亚洲黄色在线看| 亚洲国产激情| 亚洲激情综合| 亚洲国产欧美国产综合一区| 在线成人亚洲| 1769国产精品| 在线观看欧美亚洲| 在线免费日韩片| 亚洲国产你懂的| 亚洲人成在线观看网站高清| 亚洲激情综合| 亚洲精品乱码久久久久久黑人| 亚洲高清成人| 亚洲精品免费一区二区三区| 亚洲日韩成人| 亚洲无亚洲人成网站77777| 99视频在线精品国自产拍免费观看 | 国产精品高潮粉嫩av| 欧美午夜激情视频| 国产美女精品视频免费观看| 国产日本欧美在线观看| 国模精品娜娜一二三区| 亚洲电影在线免费观看| 亚洲欧洲综合| 亚洲一区一卡| 久久久久久久一区| 欧美福利视频在线| 日韩一区二区福利| 午夜视频一区在线观看| 久热re这里精品视频在线6| 欧美国产成人在线| 国产精品国产三级国产| 国产视频久久久久| 在线播放中文一区| 在线午夜精品自拍| 欧美一区二区女人| 欧美α欧美αv大片| 日韩视频专区| 久久精品三级| 欧美日韩精品欧美日韩精品| 国产欧美日韩视频一区二区| 亚洲国产精品久久久| 国产精品99久久久久久有的能看| 久久国产精品毛片| 亚洲三级视频在线观看| 午夜精品视频在线观看一区二区 | 亚洲一区二区少妇| 老巨人导航500精品| 国产精品久久7| 亚洲国内高清视频| 欧美一区二区三区日韩| 亚洲品质自拍| 久久国产视频网| 国产精品v日韩精品v欧美精品网站| 韩国一区二区三区在线观看| 一本一本久久a久久精品综合麻豆| 久久精品30| 亚洲天堂av在线免费观看| 欧美sm极限捆绑bd| 国产自产在线视频一区| 亚洲女人小视频在线观看| 亚洲国产经典视频| 久久久久免费观看| 国产香蕉久久精品综合网|