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

alpc60 ACM/ICPC程序設計
成長的路……源
posts - 20,comments - 42,trackbacks - 0
 

網絡流

1273 Drainage Ditches

這是一道比較單純的網絡流,題目要求只要求出源點到匯點的最大流就行了,而并不需要任何的建模抽象的東西,唯一一點要注意的是,要考慮有重邊的情況。

這里我用的是增廣路法求的最大流,流從源點s出發,用BFS找到一條增廣路徑,然后找這條路徑上的最小值min,對增廣路進行擴展,每一次擴展會使得f[pre[i]][i]的值增大,那么它的反向路徑f[i][pre[i]]的值會減小,一直進行下去,直到找不到增廣路為止,算法結束。

Source

 

Problem Id:1273 User Id:linyangfei

Memory:240K Time:15MS

Language:C++ Result:Accepted

 

Source

 

#include <stdio.h>

#include <string.h>

 

int n,m,pre[205];

int f[205][205];

bool mark[205];

 

int bfs();

__int64 MaxFlow();

 

int main()

{

       int i,s,e,c;

       //freopen("1273.in","r",stdin);

       while(scanf("%d%d",&m,&n)!=EOF)

       {

              memset(f,0,sizeof(f));

              for(i=0; i<m; i++)

              {

                     scanf("%d%d%d",&s,&e,&c);

                     if(f[s-1][e-1]==0)

                            f[s-1][e-1]=c;

                     else

                            f[s-1][e-1]+=c;

              }

              printf("%I64d\n",MaxFlow());

       }

       return 0;

}

 

int bfs()

{

       int q[205],qt=0,qh=1,i,x,min;

       q[qt]=0;

       mark[0]=true;

       while(qt<qh)

       {

              x=q[qt];

              if(x==n-1)

              {

                     min=100000000;

                     for(i=n-1; pre[i]!=-1; i=pre[i])

                            min=f[pre[i]][i]<min?f[pre[i]][i]:min;

                     return min;

              }

              for(i=1; i<n; i++)

              {

                     if(!mark[i] && f[x][i]>0)

                     {

                            q[qh++]=i;

                            mark[i]=true;

                            pre[i]=x;

                     }

              }

              qt++;

       }

       return 0;

}

 

__int64 MaxFlow()

{

       int i,min;

       __int64 maxflow=0;

       memset(mark,0,sizeof(mark));

       for(i=0; i<n; i++)

              pre[i]=-1;

       while(min=bfs())

       {

              for(i=n-1; pre[i]!=-1; i=pre[i])

              {

                     f[pre[i]][i]-=min;

                     f[i][pre[i]]+=min;

                    

              }

              maxflow+=min;

              memset(mark,0,sizeof(mark));

              for(i=0; i<n; i++)

                     pre[i]=-1;

       }

       return maxflow;    

}

1149 PIGS

       也是一道很經典的網絡流的題目,題目大意是MirkoM個豬圈,豬圈里面有一定數量的豬,但他沒有鑰匙,而只有來買豬的顧客才會有一些特定房間的鑰匙,每次顧客來之前,都跟Mirko預約好,所以Mirko的任務就是找出一個計劃,使他能賣出最多數量的豬。對于每位顧客,Mirko可以選擇賣出豬的數量,也可以在該顧客打開的豬圈間任意調整豬的數量,每個豬圈的容量無限大。

       我覺得這個問題的一個關鍵點是建模,如何建立一個網絡流的模型很關鍵。我把所有的豬圈統一看成一個大的源點S,把每個顧客看成是一個節點,然后再人工地添加一個匯點。這樣可以得出下面的路徑關系。

1、 在先到的顧客和后到的顧客之間有一條路徑,指向后到的顧客,這條路徑的容量無限大。

2、 在源點有指向各個顧客的路徑,路徑的容量為顧客擁有的鑰匙所能打開的豬圈的豬的總量,注意,當兩個顧客擁有同一把鑰匙的時候,豬圈的數量只能加到一個顧客節點的路徑上,不能重復加,他們之間的轉移關系就靠1中兩顧客間容量無限大的路徑來實現。

我想有了這兩點,把網絡流的模型建立起來后,求解的算法按照1273的模版就應該很容易了。

#include <stdio.h>

#include <string.h>

 

const int INF=100000000;

 

int f[105][105],pig[1005],key[1005][105],pre[105];

bool mark[105];

int m,n;

 

int bfs();

int MaxFlow();

 

int main()

{

       int i,j,c,p,k;

       //將豬圈看作一個大的源點0,再外加一個匯點n+1

       freopen("1149.txt","r",stdin);

       while(scanf("%d%d",&m,&n)!=EOF)

       {

              for(i=1; i<=m; i++)

                     scanf("%d",&pig[i]);

              memset(f,0,sizeof(f));

              memset(key,0,sizeof(key));

              for(i=1; i<=n; i++)

              {

                     scanf("%d",&c);                         //每位顧客擁有鑰匙的數量

                     for(j=1; j<=c; j++)

                     {

                            scanf("%d",&p);                  //輸入每把鑰匙的編號

                            f[0][i]+=pig[p];

                            key[p][i]=1;

                            pig[p]=0;

                     }

                     scanf("%d",&c);                         //輸入每位顧客需要豬的數量

                     f[i][n+1]=c;

              }

              for(i=1; i<=m; i++)

                     for(j=1; j<=n; j++)

                     {

                            if(key[i][j])

                                   for(k=j+1; k<=n; k++)

                                   {

                                          if(key[i][k])

                                                 f[j][k]=INF;

                                   }

                     }

              printf("%d\n",MaxFlow());

       }

       return 0;

}

int bfs()

{

       int q[205],qt=0,qh=1,i,x,min;

       q[qt]=0;

       mark[0]=true;

       while(qt<qh)

       {

              x=q[qt];

              if(x==n+1)

              {

                     min=100000000;

                     for(i=n+1; pre[i]!=-1; i=pre[i])

                            min=f[pre[i]][i]<min?f[pre[i]][i]:min;

                     return min;

              }

              for(i=1; i<=n+1; i++)

              {

                     if(!mark[i] && f[x][i]>0)

                     {

                            q[qh++]=i;

                            mark[i]=true;

                            pre[i]=x;

                     }

              }

              qt++;

       }

       return 0;

}

 

int MaxFlow()

{

       int i,min;

       int maxflow=0;

       memset(mark,0,sizeof(mark));

       for(i=0; i<=n+1; i++)

              pre[i]=-1;

       while(min=bfs())

       {

              for(i=n+1; pre[i]!=-1; i=pre[i])

              {

                     f[pre[i]][i]-=min;

                     f[i][pre[i]]+=min;

                    

              }

              maxflow+=min;

              memset(mark,0,sizeof(mark));

              for(i=0; i<=n+1; i++)

                     pre[i]=-1;

       }

       return maxflow;    

}

 

posted on 2007-09-22 17:09 飛飛 閱讀(860) 評論(2)  編輯 收藏 引用 所屬分類: ACM/ICPC

FeedBack:
# re: 網絡流
2009-09-09 12:50 | yyz_max@163.com
很好很強大  回復  更多評論
  
# re: 網絡流
2009-09-09 15:03 | yyz_max@163.com
看來主要是建模的問題啊  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美精品手机在线| 久久一区国产| 国内精品久久久久影院色| 欧美日韩一卡二卡| 国产精品国产一区二区| 国产精品一卡| 国产一区在线播放| 亚洲青色在线| 亚洲一级二级| 久久精品国产免费看久久精品| 香蕉亚洲视频| 免费成人在线观看视频| 最近中文字幕日韩精品| 亚洲福利小视频| 99精品国产在热久久下载| 亚洲欧美日韩精品久久| 久久中文欧美| 国产精品美女久久久久av超清| 国产女人精品视频| 亚洲国产欧美另类丝袜| 亚洲天堂视频在线观看| 久久国产欧美日韩精品| 久久综合久久综合久久综合| 欧美成人精品福利| 日韩午夜激情电影| 亚洲一区3d动漫同人无遮挡| 久久九九免费视频| 欧美色图首页| 欲色影视综合吧| 亚洲自拍偷拍视频| 久久综合国产精品台湾中文娱乐网| 亚洲丰满在线| 久久爱www.| 欧美视频精品在线| 亚洲激情在线视频| 久久久久久黄| 在线亚洲+欧美+日本专区| 免费成人黄色av| 国产日韩欧美精品在线| 99日韩精品| 欧美激情视频网站| 欧美在线free| 国产欧美精品日韩精品| 亚洲一区二区在线免费观看| 欧美国产乱视频| 久久精品首页| 国产欧美日韩另类视频免费观看| 亚洲黄色在线观看| 久久久一二三| 亚洲午夜激情免费视频| 欧美日本精品一区二区三区| 激情国产一区| 久久精品首页| 欧美一级免费视频| 国产精品区一区二区三区| 亚洲精品一区在线观看| 美女脱光内衣内裤视频久久影院| 久久福利影视| 亚洲一区二区三区777| 欧美日本韩国| 一区二区三区四区五区精品视频 | 欧美一区二区三区在线观看视频| 亚洲第一页中文字幕| 欧美在线亚洲一区| 国产日韩欧美夫妻视频在线观看| 亚洲性图久久| 一道本一区二区| 欧美三级电影一区| 亚洲在线观看| 亚洲一区制服诱惑| 国产精品一区二区三区四区五区| 亚洲视频播放| 在线视频亚洲| 国产精品亚洲综合一区在线观看| 欧美亚洲综合另类| 午夜久久一区| 激情综合久久| 欧美高清视频免费观看| 欧美高清hd18日本| 欧美成人r级一区二区三区| 欧美综合二区| 一色屋精品亚洲香蕉网站| 免费成人黄色片| 欧美精选在线| 欧美一二三视频| 久久免费国产精品1| 久久久久久久久久久久久久一区| 一区二区三区在线观看欧美| 欧美激情一区二区三区成人| 欧美色欧美亚洲高清在线视频| 香蕉乱码成人久久天堂爱免费| 欧美在线视频免费| 91久久极品少妇xxxxⅹ软件| 99国产精品视频免费观看| 国产精品久久91| 久久久久久久久一区二区| 老司机午夜精品视频| 中文在线一区| 久久精品国产99| 日韩视频专区| 欧美一级视频免费在线观看| 亚洲狼人综合| 欧美一二区视频| 日韩一级网站| 性色av一区二区三区在线观看| 亚洲国产精品久久久久婷婷884| 亚洲日本中文字幕区| 国产精品免费一区二区三区在线观看| 久久欧美中文字幕| 欧美日韩成人在线播放| 久久男人资源视频| 欧美va天堂va视频va在线| 午夜激情综合网| 免费看黄裸体一级大秀欧美| 欧美伊人久久| 欧美精品七区| 久久综合网络一区二区| 国产精品色在线| 亚洲第一视频| 国产在线成人| 亚洲欧美国产精品专区久久| 亚洲视频在线播放| 久久综合伊人| 久久人人97超碰人人澡爱香蕉| 欧美人与禽猛交乱配| 免费不卡中文字幕视频| 国产精品视频网站| 亚洲精品小视频在线观看| 在线精品国精品国产尤物884a| 亚洲自拍电影| 亚洲网址在线| 欧美劲爆第一页| 嫩草国产精品入口| 国内自拍一区| 欧美影视一区| 欧美一区二区三区喷汁尤物| 国产精品国产三级国产aⅴ无密码| 亚洲高清视频在线| 亚洲成色777777女色窝| 欧美在线免费观看| 久久精品导航| 国内精品视频666| 欧美激情乱人伦| 国产精品夫妻自拍| 亚洲国产精品成人综合色在线婷婷 | 欧美亚洲免费电影| 欧美亚洲免费电影| 国产美女扒开尿口久久久| 亚洲午夜精品| 久久激情视频| 一区二区视频免费完整版观看| 久久成年人视频| 免费亚洲电影在线| 亚洲黄色免费电影| 欧美日本韩国| 久久久久国内| 在线观看日韩精品| 欧美成人国产一区二区| 亚洲黑丝在线| 亚洲综合色在线| 国产一区二区三区黄| 久久久久久久久岛国免费| 亚洲国产另类久久精品| 一区二区三区四区国产精品| 国产精品一区免费在线观看| 欧美在线黄色| 亚洲国产精品女人久久久| 亚洲午夜久久久久久久久电影网| 国产精品久久99| 久久黄色网页| 亚洲电影专区| 亚洲欧美日韩国产| 国产一区二区三区在线免费观看| 久久久久久999| 亚洲精品永久免费精品| 久久久av网站| 亚洲欧洲日本一区二区三区| 国产精品二区在线观看| 久久久久久一区二区| 日韩视频一区二区在线观看| 久久久女女女女999久久| 韩国三级电影久久久久久| 欧美一区二区三区免费观看视频| 99国产精品久久久久久久| 欧美日韩亚洲免费| 性欧美暴力猛交69hd| 亚洲国产天堂久久综合| 欧美一区二区三区久久精品茉莉花| 亚洲大黄网站| 国产精品午夜av在线| 鲁大师影院一区二区三区| 亚洲视频一二区| 亚洲大片在线| 久久久亚洲国产美女国产盗摄| 亚洲无限av看| 一区二区高清视频在线观看| 1024欧美极品| 国产欧美一区二区三区在线老狼 | 制服诱惑一区二区| 欧美成人免费在线|