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

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 小果子 閱讀(5150) 評論(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>
            久久亚洲视频| 亚洲国产小视频在线观看| 欧美一级网站| 国产精品久久久久免费a∨大胸| 亚洲精选视频免费看| 一本久久综合| 国产精品一区二区在线观看不卡| 亚洲一区二区在线播放| 久久久欧美一区二区| 亚洲国产影院| 国产一在线精品一区在线观看| 久久免费视频观看| 国产亚洲欧美日韩一区二区| 午夜精品亚洲| 欧美一级欧美一级在线播放| 在线视频你懂得一区| 欧美亚洲综合久久| 国产精品一区二区a| 久久只精品国产| 亚洲国产精品123| 亚洲精品美女久久7777777| 欧美日韩国产不卡| 欧美一区二区三区免费看| 另类综合日韩欧美亚洲| 亚洲国产精品一区二区第一页| 你懂的国产精品| 日韩亚洲欧美在线观看| 国产精品99久久久久久久久久久久 | 国产亚洲一区二区三区在线观看| 久久青草欧美一区二区三区| 一区二区三区四区五区精品| 亚洲高清视频一区| 免费在线观看成人av| 久久中文欧美| 欧美不卡高清| 久久综合一区二区| 麻豆av一区二区三区久久| 久久精品亚洲一区二区三区浴池| 欧美一区二区在线免费观看| 午夜欧美大片免费观看| 欧美一区二区三区免费观看视频| 老鸭窝91久久精品色噜噜导演| 亚洲电影第1页| 亚洲高清资源| 欧美日韩视频一区二区| 欧美午夜无遮挡| 欧美一二三视频| 欧美成人午夜| 99精品热视频| 韩国av一区二区三区在线观看| 亚洲国产精品久久人人爱蜜臀| 午夜精品福利一区二区三区av| 蜜臀av国产精品久久久久| 亚洲无亚洲人成网站77777| 久久一本综合频道| 国产专区精品视频| 欧美国产专区| 欧美高清视频在线| 亚洲欧美区自拍先锋| 亚洲高清不卡在线观看| 久久久久国产一区二区三区四区| 国产精品一区二区久久精品| 亚洲一区精品视频| 亚洲国产va精品久久久不卡综合| 亚洲第一综合天堂另类专| 亚洲国产精品国自产拍av秋霞| 免费看亚洲片| 久久久久久97三级| 久久亚洲精品视频| 久久国产精品毛片| 国产精品私拍pans大尺度在线| 欧美三级在线视频| 亚洲欧美在线一区| 久久国产精品99国产精| 久久疯狂做爰流白浆xx| 亚洲香蕉伊综合在人在线视看| 欧美激情国产高清| 一二美女精品欧洲| 欧美一级精品大片| 久久成人一区| 欧美a级片一区| 狂野欧美性猛交xxxx巴西| 亚洲一区二区三区涩| 亚洲性色视频| 国产精品99久久久久久久久久久久| 91久久线看在观草草青青| 精品99视频| 欧美日韩成人一区二区三区| 久久综合久久综合九色| 久久九九精品| 久久久久久久999精品视频| 亚洲激情欧美| 欧美日韩国产精品专区| 欧美一区二区三区视频| 久久久久国产一区二区| 亚洲影院在线观看| 欧美日本一道本在线视频| 久久手机精品视频| 亚洲无线视频| 亚洲人精品午夜在线观看| 欧美激情日韩| 欧美日韩亚洲成人| 亚洲欧美在线免费| 欧美日韩国产专区| 国产女主播一区| 亚洲伊人伊色伊影伊综合网| 欧美成人在线免费视频| 久久gogo国模裸体人体| 欧美先锋影音| 亚洲国产精品成人综合色在线婷婷 | 欧美精品久久久久a| 欧美日本不卡| 国产亚洲毛片| 在线观看国产一区二区| 一区二区三区 在线观看视| 久久亚洲精选| av成人免费在线观看| 久久狠狠婷婷| 亚洲精品美女在线观看| av72成人在线| 亚洲精品综合精品自拍| 午夜在线视频观看日韩17c| 在线视频一区二区| 欧美精品videossex性护士| 久久尤物电影视频在线观看| 国产精品一区一区| 亚洲夜间福利| 欧美一区二区网站| 欧美特黄一级| 亚洲影院免费观看| 午夜视频一区二区| 国产精品一区=区| 欧美一区日韩一区| 久久手机免费观看| 激情久久五月天| 快播亚洲色图| 亚洲精品久久久一区二区三区| 1024亚洲| 亚洲黑丝一区二区| 欧美激情区在线播放| 精品99一区二区| 亚洲国产欧美不卡在线观看| 嫩模写真一区二区三区三州| 尤物九九久久国产精品的分类| 在线一区二区三区四区五区| 亚洲美女毛片| 国产精品一卡| 蜜臀91精品一区二区三区| 久久久伊人欧美| 性做久久久久久免费观看欧美| 1769国内精品视频在线播放| 欧美激情免费在线| 永久久久久久| 欧美精品福利| 久久成人综合网| 亚洲国产乱码最新视频| 欧美日韩亚洲一区二区三区四区| 亚洲国产精品一区制服丝袜| 亚洲国产精品视频| 国产精品你懂的| 亚洲欧洲日产国产综合网| 欧美网站在线观看| 久久永久免费| 国内精品美女在线观看| 中文国产一区| 亚洲欧洲精品成人久久奇米网| 欧美va日韩va| 欧美日韩在线精品| 欧美11—12娇小xxxx| 国产精品永久免费| 亚洲午夜视频在线观看| 国产一区二区在线观看免费播放| 久久久精品免费视频| 国产精品99久久久久久久久| 亚洲第一视频| 欧美国产日韩一二三区| 正在播放亚洲| 亚洲激情一区二区| 亚洲国产日韩欧美在线图片| 国产一区成人| 国产日韩欧美在线看| 欧美色综合网| 国产精品久久福利| 免费亚洲电影在线| 噜噜噜91成人网| 欧美美女bbbb| 国产精品美女www爽爽爽| 国产精品美女视频网站| 国产欧美精品一区aⅴ影院| 国产精品视频一二三| 国产一区二区三区在线观看网站 | 欧美不卡视频一区| 麻豆精品91| 亚洲国产精品久久人人爱蜜臀 | 国产色爱av资源综合区| 国产精品一区二区三区乱码 | 国内精品视频666| 亚洲第一中文字幕在线观看| 亚洲精品中文字| 久久久久久久一区二区三区|