• <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>

            Reiks的技術(shù)博客

            C/C++/STL/Algorithm/D3D
            posts - 17, comments - 2, trackbacks - 0, articles - 0
              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            最大流 Edmonds-Karp

            Posted on 2009-08-29 13:39 reiks 閱讀(764) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 算法與數(shù)據(jù)結(jié)構(gòu)
            //Edmonds-Karp
            //return the largest flow;flow[] will record every edge's flow
            //n, the number of nodes in the graph;cap, the capacity 
            //O(VE^2) 
            #define N 100
            #define inf 0x3f3f3f3f
            int Edmonds_Karp(int n,int cap[][N],int source,int sink)
            {
                
            int flow[N][N];
                
            int pre[N],que[N],d[N]; // d 是增廣路長(zhǎng)度,pre 記錄前驅(qū),que是BFS隊(duì)列
                int p,q,t,i,j;
                
            if (source==sink) return inf;
                memset(flow,
            0,sizeof(flow));
                
            while (true)
                
            {
                    memset(pre,
            -1,sizeof(pre));
                    d[source]
            =inf;
                    p
            =q=0, que[q++= source;
                    
            while(p < q&&pre[sink]<0)    // BFS 找路徑
                    {
                        t
            =que[p++];
                        
            for (i=0;i<n;i++)
                            
            if ( pre[i]<0 && (j=cap[t][i]-flow[t][i]) ) // j取得殘余路徑值
                                pre[que[q++= i] = t,d[i] = min(d[t], j);
                    }

                    
            if (pre[sink]<0break;    // 找不到增廣路,退出
                    for (i=sink; i!=source; i=pre[i])
                    
            {        
                        flow[pre[i]][i]
            +=d[sink];    // 正向流量加
                        flow[i][pre[i]]-=d[sink];    // 反向流量減
                    }

                }

                
            for (j=i=0; i<n; j+=flow[source][i++]);
                
            return j;
            }
            国产高清国内精品福利99久久| 精品熟女少妇aⅴ免费久久| 亚洲国产另类久久久精品黑人 | 国产精品久久久久无码av| 青草影院天堂男人久久| 九九精品久久久久久噜噜| 久久精品国产第一区二区三区| 欧美精品福利视频一区二区三区久久久精品 | 午夜精品久久影院蜜桃| 国产精品久久自在自线观看| 精品久久久久成人码免费动漫| 久久r热这里有精品视频| 亚洲精品无码专区久久久| 精品国产综合区久久久久久| 国内精品久久人妻互换| 亚洲AV乱码久久精品蜜桃| 久久夜色精品国产噜噜亚洲a| 国产香蕉97碰碰久久人人| 精品乱码久久久久久久| 精品伊人久久大线蕉色首页| 日韩欧美亚洲国产精品字幕久久久| 国产成人久久精品激情 | 久久久久久人妻无码| 免费精品国产日韩热久久| 无码任你躁久久久久久| 欧美性猛交xxxx免费看久久久| 精品久久久久久久久久中文字幕 | 日本久久中文字幕| 蜜桃麻豆www久久国产精品| 精品久久久久久久久久中文字幕| 久久综合狠狠色综合伊人| 亚洲国产精品婷婷久久| 国产福利电影一区二区三区,免费久久久久久久精 | 精品综合久久久久久98| 久久九九兔免费精品6| 久久国产免费直播| 亚洲级αV无码毛片久久精品| 色综合久久久久综合体桃花网| 久久精品aⅴ无码中文字字幕不卡| 久久人人爽爽爽人久久久| 久久国产精品久久|