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

USACO 4.2.2 第一道網絡流····

Posted on 2010-03-26 13:04 rikisand 閱讀(447) 評論(0)  編輯 收藏 引用 所屬分類: C/C++USACO

Drainage Ditches
Hal Burch

Every time it rains on Farmer John's fields, a pond forms over Bessie's favorite clover patch. This means that the clover is covered by water for awhile and takes quite a long time to regrow. Thus, Farmer John has built a set of drainage ditches so that Bessie's clover patch is never covered in water. Instead, the water is drained to a nearby stream. Being an ace engineer, Farmer John has also installed regulators at the beginning of each ditch, so he can control at what rate water flows into that ditch.

Farmer John knows not only how many gallons of water each ditch can transport per minute but also the exact layout of the ditches, which feed out of the pond and into each other and stream in a potentially complex network. Note however, that there can be more than one ditch between two intersections.

Given all this information, determine the maximum rate at which water can be transported out of the pond and into the stream. For any given ditch, water flows in only one direction, but there might be a way that water can flow in a circle.

PROGRAM NAME: ditch
INPUT FORMAT

Line 1:
Two space-separated integers, N (0 <= N <= 200) and M (2 <= M <= 200). N is the number of ditches that Farmer John has dug. M is the number of intersections points for those ditches. Intersection 1 is the pond. Intersection point M is the stream.

Line 2..N+1:
Each of N lines contains three integers, Si, Ei, and Ci. Si and Ei (1 <= Si, Ei <= M) designate the intersections between which this ditch flows. Water will flow through this ditch from Si to Ei. Ci (0 <= Ci <= 10,000,000) is the maximum rate at which water will flow through the ditch.

SAMPLE INPUT (file ditch.in)
5 4
1 2 40
1 4 20
2 4 20
2 3 30
3 4 10
OUTPUT FORMAT

One line with a single integer, the maximum rate at which water may emptied from the pond.

SAMPLE OUTPUT (file ditch.out)
50
最基本的網絡流
   1:  #include<iostream>
   2:  #include<fstream>
   3:  #include<string>
   4:  #include<vector>
   5:  #include<map>
   6:  #include<algorithm>
   7:  #include<sstream>
   8:  #include <cstring>
   9:  #include <queue>
  10:  using namespace std;
  11:  const int MAXN = 220;
  12:  const int infi = 0x7FFFFFFF;
  13:   int capacity[MAXN][MAXN], prenode[MAXN], flow[MAXN];
  14:   queue<int> mq; 
  15:   
  16:  int start, end, N;
  17:  void init(){
  18:      freopen("ditch.in","r",stdin);
  19:      //freopen("e:\\usaco\\ditch.in","r",stdin);
  20:      start = 1;  
  21:      scanf("%d %d",&N,&end); int c, s, t;
  22:      memset(capacity,0,sizeof(capacity));
  23:      for(int i=0;i<N;i++)
  24:      {
  25:          scanf("%d %d %d",&c,&s,&t);
  26:          capacity[c][s] += t; //兩個節點間不只有一條路
  27:      } 
  28:  }
  29:  int bfs(){//尋找增廣路徑
  30:      while(!mq.empty()) mq.pop(); 
  31:      mq.push(start);  //源節點入隊
  32:      //memset(flow,0,sizeof(flow));
  33:      memset(prenode,-1,sizeof(prenode)); //重置前向節點
  34:      prenode[start] = 0; flow[start]=infi; //源節點流量無限大
  35:      while(!mq.empty()){
  36:          int cur = mq.front(); 
  37:          mq.pop();
  38:          if(cur == end) break; //到達匯點結束路徑 
  39:          for(int i=1;i<=end;i++){ 
  40:              if(prenode[i]==-1 && capacity[cur][i]) //訪問當前節點所有未訪問的相鄰節點,更新flow
  41:              {
  42:                  prenode[i] = cur;
  43:                  flow[i] = (flow[cur]<capacity[cur][i]?flow[cur]:capacity[cur][i]);
  44:                  mq.push(i);
  45:              }
  46:          }
  47:      }
  48:      if(prenode[end]==-1)  //如果未找到增廣路徑返回-1
  49:          return -1;
  50:      return flow[end];
  51:  }
  52:  int Edmonds_Karp(){
  53:      int total = 0, pathcapacity;//pathcapacity 路徑增加量
  54:      while((pathcapacity = bfs()) != -1){//可以找到增廣路徑時候進行循環
  55:          int cur = end;    //從匯點開始增加逆向節點
  56:          while( cur != start ){
  57:              int t = prenode[cur] ;
  58:              capacity[t][cur] -= pathcapacity;
  59:              capacity[cur][t] += pathcapacity;
  60:              cur = t;
  61:          }
  62:          total += pathcapacity;//max_flow
  63:      }
  64:      return total;
  65:  }
  66:  void output(){
  67:      freopen("ditch.out","w",stdout);
  68:      //freopen("c:\\usaco\\ditch.out","w",stdout);
  69:      cout<<Edmonds_Karp()<<endl;
  70:  } 
  71:     int main()
  72:  {
  73:      init();  
  74:      output();
  75:      return 0;
  76:  }

標程:使用貪心法,尋找一條增廣路徑的時候不斷尋找cap最大的,未被訪問的節點mloc;然后更新跟mloc相鄰的節點flow以

及prenode信息.最后當運行到end時候,更新路徑節點capacity,同時增加max_flow.重復上述過程直到找不到增廣路徑

   1:  #include <stdio.h>
   2:  #include <string.h>
   3:   
   4:  #define MAXI 200
   5:   
   6:  /* total drain amount between intersection points */
   7:  int drain[MAXI][MAXI];
   8:  int nint; /* number of intersection points */
   9:   
  10:  int cap[MAXI]; /* amount of flow that can get to each node */
  11:  int vis[MAXI]; /* has this node been visited by Dijkstra's yet? */
  12:  int src[MAXI]; /* the previous node on the path from the source to here */
  13:   
  14:  int augment(void)
  15:   { /* run a Dijkstra's varient to find maximum augmenting path */
  16:    int lv;
  17:    int mloc, max;
  18:    int t;
  19:   
  20:    memset(cap, 0, sizeof(cap));
  21:    memset(vis, 0, sizeof(vis));
  22:   
  23:    cap[0] = 2000000000;
  24:    while (1)
  25:     {
  26:      /* find maximum unvisited node */
  27:      max = 0;
  28:      mloc = -1;
  29:      for (lv = 0; lv < nint; lv++)
  30:        if (!vis[lv] && cap[lv] > max)
  31:         {
  32:          max = cap[lv];
  33:      mloc = lv;
  34:         }
  35:      if (mloc == -1) return 0;
  36:      if (mloc == nint-1) break; /* max is the goal, we're done */
  37:   
  38:      vis[mloc] = -1; /* mark as visited */
  39:   
  40:      /* update neighbors, if going through this node improves the
  41:         capacity */
  42:      for (lv = 0; lv < nint; lv++)
  43:        if (drain[mloc][lv] > cap[lv] && max > cap[lv])
  44:         {
  45:          cap[lv] = drain[mloc][lv];
  46:      if (cap[lv] > max) cap[lv] = max;
  47:      src[lv] = mloc;
  48:         }
  49:     }
  50:    max = cap[nint-1];
  51:   
  52:    /* augment path, starting at end */
  53:    for (lv = nint-1; lv > 0; lv = src[lv])
  54:     {
  55:      t = src[lv];
  56:      drain[t][lv] -= max;
  57:      drain[lv][t] += max;
  58:     }
  59:    return max;
  60:   }
  61:   
  62:  int main(int argc, char **argv)
  63:   {
  64:    FILE *fout, *fin;
  65:    int lv;
  66:    int num;
  67:    int p1, p2, c;
  68:   
  69:    if ((fin = fopen("ditch.in", "r")) == NULL)
  70:     {
  71:      perror ("fopen fin");
  72:      exit(1);
  73:     }
  74:    if ((fout = fopen("ditch.out", "w")) == NULL)
  75:     {
  76:      perror ("fopen fout");
  77:      exit(1);
  78:     }
  79:   
  80:    fscanf (fin, "%d %d", &num, &nint);
  81:    while (num--)
  82:     {
  83:      fscanf (fin, "%d %d %d", &p1, &p2, &c);
  84:      p1--;
  85:      p2--;
  86:      drain[p1][p2] += c; /* note += handles two ditches between same points */
  87:     }
  88:   
  89:    /* max flow algorithm: augment while you can */
  90:    c = 0;
  91:    while ((p1 = augment()))
  92:      c += p1;
  93:    fprintf (fout, "%d\n", c);
  94:    return 0;
  95:   }

 

 

 

 

 

 

 

 

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久久久**毛片大全| 国产偷国产偷亚洲高清97cao | 一色屋精品亚洲香蕉网站| 国产精品国产三级国产普通话三级| 欧美精品久久久久久| 欧美视频亚洲视频| 国产精品免费看片| 国产欧美日韩免费看aⅴ视频| 国产日韩欧美一区| 亚洲国产精品一区二区尤物区| 日韩香蕉视频| 小嫩嫩精品导航| 美女亚洲精品| 一区二区日韩欧美| 久久精品99国产精品| 欧美金8天国| 国产免费成人| 亚洲免费精品| 久久久久久久久综合| 亚洲欧洲一二三| 亚洲欧美一区二区三区久久| 蜜臀久久久99精品久久久久久| 欧美午夜电影一区| 亚洲国产婷婷香蕉久久久久久99| 亚洲一区二区三区在线| 久久天天躁狠狠躁夜夜av| 亚洲精选中文字幕| 久久综合五月| 国产视频在线观看一区| 一区二区三区四区国产| 麻豆精品在线观看| 亚洲免费在线视频| 欧美日本中文字幕| 亚洲国产精品福利| 久久久五月天| 欧美一区二区三区精品| 欧美日韩一区二区在线| 亚洲国产岛国毛片在线| 久久精品一区二区国产| 夜色激情一区二区| 欧美国产日本| 亚洲国产精品视频| 久久天天躁夜夜躁狠狠躁2022 | 最新成人av网站| 久久gogo国模裸体人体| 国产精品久久久久久妇女6080| 日韩视频在线永久播放| 久久久久久久久久久久久9999| 亚洲性感美女99在线| 欧美日韩国产成人高清视频| 亚洲精品久久久久久久久久久| 麻豆久久婷婷| 久久成人精品无人区| 国产精品久久久久久一区二区三区| 99ri日韩精品视频| 亚洲大片一区二区三区| 久久久精品一区| 国产伊人精品| 久久网站热最新地址| 欧美一区视频在线| 国产主播精品在线| 久久婷婷蜜乳一本欲蜜臀| 欧美一区高清| 伊人影院久久| 亚洲二区在线视频| 欧美日韩在线看| 亚洲手机成人高清视频| 亚洲最新在线视频| 国产欧美日韩综合一区在线观看| 欧美一区三区三区高中清蜜桃| 亚洲欧美网站| 在线观看亚洲一区| 亚洲欧洲中文日韩久久av乱码| 欧美另类极品videosbest最新版本 | 欧美高清视频| 夜夜嗨av一区二区三区中文字幕 | 欧美电影免费观看| 欧美大色视频| 亚洲桃色在线一区| 亚洲一区日韩在线| 国产一区二区三区的电影| 久久综合九色综合欧美就去吻| 蜜桃av一区二区三区| 中文国产成人精品久久一| 亚洲午夜电影在线观看| 狠狠综合久久av一区二区老牛| 亚洲第一区中文99精品| 欧美视频在线看| 久久色中文字幕| 欧美日韩成人在线视频| 久久精品成人| 欧美区亚洲区| 久久久久久久999| 欧美激情中文不卡| 久久成人这里只有精品| 欧美国产在线观看| 久久久91精品国产一区二区三区| 欧美不卡视频一区| 久久精品人人做人人爽| 欧美激情1区2区3区| 欧美专区在线观看| 欧美乱妇高清无乱码| 久久久精品久久久久| 欧美日韩精品综合| 你懂的亚洲视频| 国产精品亚洲欧美| 精品成人在线观看| 亚洲欧美在线视频观看| 看欧美日韩国产| 欧美在线免费看| 欧美日韩国产一区精品一区| 麻豆freexxxx性91精品| 国产精品大片| 亚洲欧洲日本专区| 影视先锋久久| 欧美一区91| 午夜视频在线观看一区二区| 欧美日韩国产黄| 亚洲国产精品va在线观看黑人| 亚洲电影自拍| 国产精品久久久久久久电影| 亚洲国产一二三| 曰韩精品一区二区| 久久久www成人免费精品| 欧美一级网站| 欧美午夜视频在线| 一本久久综合亚洲鲁鲁五月天| 亚洲精品一区中文| 欧美~级网站不卡| 欧美肥婆bbw| 91久久黄色| 欧美国产日韩亚洲一区| 亚洲电影av| 亚洲精品欧美在线| 欧美国产专区| 亚洲三级免费观看| 亚洲一本大道在线| 国产精品理论片在线观看| 中文在线不卡| 欧美一区2区视频在线观看| 国产裸体写真av一区二区| 亚洲一区精品电影| 久久国产精品99精品国产| 国产日韩精品一区观看| 欧美一区二区日韩| 欧美成人精品不卡视频在线观看| 亚洲国产成人精品久久| 欧美日韩国产一区| 亚洲小视频在线| 久久久久久一区二区三区| 极品尤物一区二区三区| 噜噜噜躁狠狠躁狠狠精品视频 | 久久夜色精品亚洲噜噜国产mv| 欧美99久久| 日韩小视频在线观看专区| 欧美午夜精品一区| 欧美一级片在线播放| 女人色偷偷aa久久天堂| 亚洲毛片在线观看| 欧美视频手机在线| 久久精品国产99国产精品澳门| 欧美激情第二页| 亚洲欧美精品伊人久久| 精品不卡一区二区三区| 欧美日韩成人网| 久久久精品国产免大香伊| 亚洲国产欧美一区二区三区久久| 亚洲小说欧美另类婷婷| 国色天香一区二区| 欧美精品激情blacked18| 亚洲午夜精品17c| 欧美不卡福利| 久久蜜桃精品| 亚洲高清视频在线| 亚洲一区二区三区四区五区午夜 | 国产最新精品精品你懂的| 欧美成人小视频| 午夜精品免费| 亚洲国产一区二区视频| 午夜亚洲激情| 亚洲美女性视频| 国产亚洲二区| 欧美日韩一区二区三区免费| 久久av红桃一区二区小说| 亚洲精品欧美一区二区三区| 久久久久久伊人| 午夜激情一区| 9l国产精品久久久久麻豆| 国内一区二区三区| 国产精品视频精品视频| 欧美伦理a级免费电影| 久久久久久高潮国产精品视| 亚洲性夜色噜噜噜7777| 亚洲国产欧美一区二区三区丁香婷| 久久精品国产视频| 午夜在线精品偷拍| 亚洲无人区一区| 艳妇臀荡乳欲伦亚洲一区| 亚洲国产欧美一区| 精品成人一区二区三区四区|