ACM - 圖論- 網路流 -
阿新 • • 發佈:2022-03-01
\(EK\) 演算法模板
#include <iostream> #include <queue> #include<string.h> using namespace std; #define arraysize 201 int maxData = 0x7fffffff; int capacity[arraysize][arraysize]; //記錄殘留網路的容量 int flow[arraysize]; //標記從源點到當前節點實際還剩多少流量可用 int pre[arraysize]; //標記在這條路徑上當前節點的前驅,同時標記該節點是否在佇列中 int n,m; queue<int> myqueue; int BFS(int src,int des) { int i,j; while(!myqueue.empty()) //佇列清空 myqueue.pop(); for(i=1;i<m+1;++i) { pre[i]=-1; } pre[src]=0; flow[src]= maxData; myqueue.push(src); while(!myqueue.empty()) { int index = myqueue.front(); myqueue.pop(); if(index == des) //找到了增廣路徑 break; for(i=1;i<m+1;++i) { if(i!=src && capacity[index][i]>0 && pre[i]==-1) { pre[i] = index; //記錄前驅 flow[i] = min(capacity[index][i],flow[index]); //關鍵:迭代的找到增量 myqueue.push(i); } } } if(pre[des]==-1) //殘留圖中不再存在增廣路徑 return -1; else return flow[des]; } int maxFlow(int src,int des) { int increasement= 0; int sumflow = 0; while((increasement=BFS(src,des))!=-1) { int k = des; //利用前驅尋找路徑 while(k!=src) { int last = pre[k]; capacity[last][k] -= increasement; //改變正向邊的容量 capacity[k][last] += increasement; //改變反向邊的容量 k = last; } sumflow += increasement; } return sumflow; } int main() { int i,j; int start,end,ci; while(cin>>n>>m) { memset(capacity,0,sizeof(capacity)); memset(flow,0,sizeof(flow)); for(i=0;i<n;++i) { cin>>start>>end>>ci; if(start == end) //考慮起點終點相同的情況 continue; capacity[start][end] +=ci; //此處注意可能出現多條同一起點終點的情況 } cout<<maxFlow(1,m)<<endl; } return 0; }