日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

最大流问题之FF算法与EK算法

發布時間:2023/12/20 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 最大流问题之FF算法与EK算法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

目錄

問題描述:

EK算法:

算法描述:

偽代碼:

例子:

控制臺對應輸出為:

關鍵定理證明:

最大流最小割定理:

1推2:

2推3:

3推1:

時間復雜度分析

分析

關鍵邊定義:

時間復雜度計算:

FF算法:

FF算法介紹

FF算法缺陷分析:


問題描述:

G=(V,E)是一個有向圖,其中每條邊(u,v)有一個非負的容量值c(u,v),而且如果E中包含一條邊(u,v),那么圖中就不存在它的反向邊。在流網絡中有兩個特殊的結點,源結點s和匯點t,源結點s只會流出不會流進,匯點只會流進不會流出,我們要求的就是從源結點流到匯結點的路徑的值之和的最大值

EK算法:

算法描述:

每次從殘留網絡中找出一條從源結點到匯結點的最短路徑,流選為路徑中的殘存容量,依據流更新殘存網絡(將每條邊的殘存容量改為當前容量減去流的大小,并添加對應的反向邊,邊的容量為流的大小)

重復選最短路徑,更新殘存網絡,直到沒有最短路徑為止

此時的流累加和即為最大流

?

由于每次要找的是最短路徑,所以需要用BFS找路徑

偽代碼

例子:

初始圖:

第一次路徑1->2->4->6,流大小:12

更新后圖為:

第二次路徑為1->3->5->6,流大小:4

更新后圖為:

?

第三次路徑為1->3->5->4->6,流大小:7

更新后圖為:

此時,再也找不到最短路徑,算法結束,則最大流為:12+4+7=23

?

控制臺對應輸出為:

?

關鍵定理證明:

最大流最小割定理:

下面條件等價

1、f是G的一個最大流

2、殘存網絡不包括任何增廣路徑

3、|f|=c(S,T),其中(S,T)是流網絡的某個切割

1推2:

假定f是G的一個最大流,但殘存網絡中仍包含有一條增廣路徑,那么對流f增加流量后,所得的值是嚴格大于f的值的,這與f是G的一個最大流矛盾

2推3:

假設流網絡G不包含任何增廣路徑,現在定義S為G中存在一條從s到v的路徑的所有v的集合,定義T為V-S,則劃分(S,T)是流網絡G的一個切割。

對S中的任意一個結點u,T中的任意一個結點v

如果(u,v)屬于E,則必有f(u,v)=c(u,v)

如果(v,u)屬于E,則必有f(v,u)=0

如果(u,v)和(v,u)都不屬于E,則f(u,v)= f(v,u)=0

因此

所以|f| = f(S,T)= c(S,T),得證

3推1:

對于所有切割(S,T),|f|≤c(S,T)

因此,當|f| = c(S,T)時,f就是一個最大流

?

時間復雜度分析

分析

對于一個流網絡,我們要分析EK算法的復雜度,實際就是要分析調用bfs的次數,但是bfs的次數是很難分析的,所以需要做一點轉換,將對bfs次數的分析轉換為其它和它等價的實體量且稍微簡單一點的分析

在實際分析中,我們發現關鍵邊的個數和bfs的次數是等價的,所以要分析bfs次數,不妨就分析關鍵邊的個數

?

關鍵邊定義:

邊(u,v)的殘存容量為最短路徑的殘存容量,則稱為為關鍵邊

任一增廣路徑都至少存在一條關鍵邊

?

時間復雜度計算:

邊(u,v)成為關鍵邊到下一次成為關鍵邊,從原結點到u的距離至少增加2個單位

②由于從源結點s到結點u的中間結點不可能包括s、u或t,所以一直到u成為不可到達結點前,距離最長為v-2

由①②可得邊(u,v)成為關鍵邊的次數最多為(V-2)/2,取V/2

?

由于一共有E條邊,所以EK算法中關鍵邊總數為O(VE)

總時間 = BFS時間 * BFS次數

由于每次BFS時間為O(E),需要O(VE)次BFS,所以總時間為O(VE2)

?

?

FF算法:

FF算法介紹

FF算法和EK算法很相似,唯一不同的地方就是FF算法每次找的不是最短增廣路徑,它找的路徑是隨機的

?

FF算法缺陷分析:

由于FF算法每次找的增廣路徑不是最短路徑,所以FF算法存在這樣一個缺陷:它會使一條邊成為關建邊的最大次數從原來的V/2上升到K/2(K為所有邊中權值最大的邊的權值)

舉下面一個例子

圖3、FF算法樣例圖

按照EK算法,邊(u,v)和(v,u)成為關鍵邊的最大次數應該是4/2-1 = 1,所以所需要的bfs次數為1+1 = 2次

圖4、FF算法過程圖

?

圖5、FF算法過程圖

在FF算法中,它將以圖4和圖5的方式反復流動500000次

邊(u,v)和(v,u)成為關鍵邊的最大次數是1000000/2=500000,所以所需要的bfs次數為500000+500000=1000000次,由于調用bfs的效率過低,所以會導致FF算法比EK算法慢

代碼:×

?

總結

以上是生活随笔為你收集整理的最大流问题之FF算法与EK算法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。