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

            POJ 1459 C++ (圖論)

            一.Ford和Fulkerson迭加算法.

              基本思路:把各條弧上單位流量的費(fèi)用看成某種長度,用求解最短路問題的方法確定一條自V1至Vn的最短路;在將這條最短路作為可擴(kuò)充路,用求解最大流問題的方法將其上的流量增至最大可能值;而這條最短路上的流量增加后,其上各條弧的單位流量的費(fèi)用要重新確定,如此多次迭代,最終得到最小費(fèi)用最大流.

              迭加算法:

              1) 給定目標(biāo)流量F或∞,給定最小費(fèi)用的初始可行流=0

              2) 若V(f)=F,停止,f為最小費(fèi)用流;否則轉(zhuǎn)(3).

              3) 構(gòu)造 相應(yīng)的新的費(fèi)用有向圖W(fij),在W(fij)尋找Vs到Vt的最小費(fèi)用有向路P(最短路),沿P增加流f的流量直到F,轉(zhuǎn)(2);若不存在從Vs到Vt的最小費(fèi)用的有向路P,停止.f就是最小費(fèi)用最大流.

              具體解題步驟:

              設(shè)圖中雙線所示路徑為最短路徑,費(fèi)用有向圖為W(fij).

              在圖(a)中給出零流 f,在圖(b)中找到最小費(fèi)用有向路,修改圖(a)中的可行流,δ=min{4,3,5}=3,得圖(c),再做出(c)的調(diào)整容量圖,再構(gòu)造相應(yīng)的新的最小費(fèi)用有向路得圖(d), 修改圖(c)中的可行流, δ=min{1,1,2,2}=1,得圖(e),以此類推,一直得到圖(h),在圖(h)中以無最小費(fèi)用有向路,停止,經(jīng)計(jì)算:

              圖(h)中 最小費(fèi)用=1*4+3*3+2*4+4*1+1*1+4*2+1*1+3*1=38

              圖(g)中 最大流=5

              最大流問題僅注意網(wǎng)絡(luò)流的流通能力,沒有考慮流通的費(fèi)用。實(shí)際上費(fèi)用因素是很重要的。例如在交通運(yùn)輸問題中,往往要求在完成運(yùn)輸任務(wù)的前提下,尋求一個(gè)使總運(yùn)輸費(fèi)用最省的運(yùn)輸方案,這就是最小費(fèi)用流問題。如果只考慮單位貨物的運(yùn)輸費(fèi)用,那么這個(gè)問題就變成最短路問題。由此可見,最短路問題是最小費(fèi)用流問題的基礎(chǔ)。現(xiàn)已有一系列求最短路的成功方法。最小費(fèi)用流(或最小費(fèi)用最大流)問題 ,可以交替使用求解最大流和最短路兩種方法,通過迭代得到解決。


            //老老實(shí)實(shí)看了一天的書,終于敲出了第一個(gè)關(guān)于網(wǎng)絡(luò)流的程序
            //慶祝流的零的突破

            #include<iostream>
            using namespace std;
            int n,np,nc,m,flag,res;
            int arr[110][110];
            int q[10000],pre[10000],used[110];

            int path(int s)
            { int u,head,tail,temp,i,j;
              head=tail=0;
              q[tail++]=s;
              used[s]=1;
              while(head<tail)
                   { temp=tail;
                     for(i=head;i<temp;i++)
                         {    u=q[i];
                              if(u==n+1)
                                 return 1;
                              for(j=0;j<=n+1;j++)
                                 if(!used[j] && arr[u][j]>0)
                                    {pre[j]=u;
                                     used[j]=1;
                                     q[tail++]=j;
                                     }
                          }
                      head=temp;
                   }
              return 0;      
            }


            void  ford_fulkerson()
            { int i,j,u,v,min;
              min=INT_MAX;
             
              u=pre[n+1];
              v=n+1;
              while(u>=0)
                   {if(arr[u][v]<min)
                         min=arr[u][v];
                       v=u;
                       u=pre[u];
                     
                   }
                
              u=pre[n+1];
              v=n+1;
              while(u>=0)
                   {   arr[u][v]=arr[u][v]-min;
                       arr[v][u]=arr[v][u]+min;
                       v=u;
                       u=pre[u];
                    }
               res=res+min;       
            }       


            int main()
            {int u,v,w,i,j;
                   freopen("in.txt","r",stdin);
                   freopen("out.txt","w",stdout);
             while((scanf("%d%d%d%d",&n,&np,&nc,&m))!=EOF)
                   {  flag=0;
                      res=0;
                      memset(arr,0,sizeof(arr));
                       for(i=0;i<m;i++)
                         { while(getchar()!='(');
                           scanf("%d,%d)%d",&u,&v,&w);
                           arr[u][v]=w;
                         } 
                       for(i=0;i<np;i++)
                         {  while(getchar()!='(');
                            scanf("%d)%d",&v,&w);
                            arr[n][v]=w;
                          } 
                     
                        for(i=0;i<nc;i++)
                         { while(getchar()!='(');
                           scanf("%d)%d",&u,&w);
                           arr[u][n+1]=w;
                          }   
                                                        
                       while(!flag)
                         { memset(used,0,sizeof(used));
                           memset(pre,-1,sizeof(pre));
                           if(path(n))
                              ford_fulkerson();
                            else
                              flag=1;
                          }     
                printf("%d\n",res);  
             }                                      
               return 0;
            }   

            posted on 2008-11-27 17:42 蝸牛 閱讀(1610) 評論(0)  編輯 收藏 引用 所屬分類: ACM ICPC

            <2008年11月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿(1)

            隨筆分類(20)

            隨筆檔案(20)

            Favorites

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久国产精品偷99| 日日狠狠久久偷偷色综合0| 99久久国产综合精品女同图片| 久久综合视频网站| 久久人妻无码中文字幕| 97精品久久天干天天天按摩| 99久久精品国产毛片| 久久青青草视频| 久久久久无码精品国产不卡| 99久久免费只有精品国产| 国内精品久久久久影院老司 | 亚洲国产精品18久久久久久| 99久久精品国产免看国产一区| 久久综合九色综合久99| 久久综合色老色| 国产高潮国产高潮久久久91 | 久久99久久无码毛片一区二区| 伊人热热久久原色播放www| 成人国内精品久久久久影院| 日韩va亚洲va欧美va久久| 99国产精品久久久久久久成人热| 亚洲国产精品嫩草影院久久| 97精品伊人久久大香线蕉app | 久久综合色之久久综合| 九九99精品久久久久久| 亚洲中文久久精品无码ww16| 久久99精品免费一区二区| 一本大道久久a久久精品综合| 伊人久久综合成人网| 伊人色综合久久天天网| 精品乱码久久久久久夜夜嗨| 97久久超碰国产精品2021| 97久久天天综合色天天综合色hd| 久久人人爽人人人人片av| 久久久久久久精品成人热色戒| 久久久久国产一级毛片高清板 | 一本一本久久a久久综合精品蜜桃| 久久久久亚洲精品男人的天堂| 伊人久久大香线蕉精品| 99久久人妻无码精品系列蜜桃 | 久久精品国产久精国产一老狼|