从1走到N然后从N走回来的最短路程是多少? 转换为费用流来建模.

   1:  /**
   2:  因为e ==0 所以 pe[v]   pe[v]^1 是两条相对应的边
   3:  E[pe[v]].c -= aug;            E[pe[v]^1].c += aug;
   4:  
   5:  */
   6:  #include <queue>
   7:  #include <iostream>
   8:  #include <string.h>
   9:  #include <stdio.h>
  10:  #include <map>
  11:  using namespace std;
  12:  #define V 30010      // vertex
  13:  #define E 150010      // edge
  14:  #define INF 0x3F3F3F3F
  15:  struct MinCostMaxFlow
  16:  {
  17:      struct Edge
  18:      {
  19:          int v, next, cap, cost;  // cap 为容量, cost为单位流量费用
  20:      } edge[E];
  21:   
  22:      int head[V], pe[V], pv[V];            // 每个节点的第一条edge[idx]的编号.
  23:      int  dis[V];            // the shortest path to the src
  24:      bool vis[V];            // visted
  25:      // pe[v]  存放在增广路上到达v的边(u,v) 在edge[]的位置
  26:      // pv[u]  存放在增广路上从u出发的边(u,v) 在edge[]中的位置
  27:      int e, src, sink;            // the index of the edge
  28:      void addedge(int  u, int v, int cap, int cost)
  29:      {
  30:          edge[e].v = v, edge[e].cap = cap;
  31:          edge[e].cost = cost,edge[e].next = head[u], head[u] = e++;
  32:          edge[e].v = u, edge[e].cap = 0;
  33:          edge[e].cost = -1*cost, edge[e].next = head[v], head[v] = e++;
  34:      }
  35:      // 求最短路,不存在负环的时候,比 DFS快
  36:      int SPFABFS()
  37:      {
  38:          memset(vis, 0 ,sizeof(vis));
  39:          memset(pv, -1, sizeof(pv));
  40:          for(int i=0; i<V; i++) dis[i] = INF;
  41:          queue<int> Q;
  42:          Q.push(src), vis[src] = 1, dis[src] = 0;
  43:          while(!Q.empty())
  44:          {
  45:              int u = Q.front();
  46:              Q.pop(), vis[u] = 0;
  47:              for(int i=head[u]; i!=-1; i=edge[i].next)
  48:              {
  49:                  int v = edge[i].v;
  50:                  if(edge[i].cap > 0 &&  dis[v] > dis[u] + edge[i].cost  )
  51:                  {
  52:                      dis[v] = dis[u] + edge[i].cost;
  53:                      if(!vis[v]) Q.push(v),vis[v] = 1;
  54:                      pv[v] = u, pe[v] = i;
  55:                  }
  56:              }
  57:          }
  58:          if(dis[sink] == INF) return -2;          // can't from src to sink.
  59:          return dis[sink];
  60:      }
  61:   
  62:      pair<int,int> MCMF()
  63:      {
  64:          int maxflow = 0, mincost = 0;
  65:          while(SPFABFS())
  66:          {
  67:              if(pv[sink] == -1) break;
  68:              int aug = INF;
  69:              for(int i= sink; i!= src; i = pv[i])
  70:                  aug =min(aug, edge[pe[i]].cap);
  71:              maxflow += aug;
  72:              mincost += aug * dis[sink];
  73:              for(int i = sink; i!= src; i = pv[i])
  74:              {
  75:                  edge[pe[i]].cap -= aug;
  76:                  edge[pe[i]^1].cap += aug;
  77:              }
  78:          }
  79:          return make_pair(maxflow, mincost);
  80:      }
  81:   
  82:      /// 一定需要初始化的是 src, sink
  83:      void solve()
  84:      {
  85:          int N,M;
  86:          while(scanf("%d%d", &N , &M)!= EOF)
  87:          {
  88:              e=0;
  89:              memset(head, -1,sizeof(head));
  90:              for(int i=0; i<M; i++)
  91:              {
  92:                  int a, b, c;
  93:                  scanf("%d%d%d", &a, &b, &c);
  94:                  addedge(a, b,1,c);
  95:                  addedge(b, a,1, c);
  96:              }
  97:              src = 0;
  98:              sink = N+1;
  99:              addedge(src,1, 2, 0);
 100:              addedge(N, sink, 2, 0);
 101:              pair<int,int> ret = MCMF();
 102:              cout<<ret.second<<endl;
 103:          }
 104:      }
 105:  } mcmf;
 106:   
 107:  int main()
 108:  {
 109:      mcmf.solve();
 110:      return 0;
 111:  }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

POJ 2315 最小费用最大流的更多相关文章

  1. poj 3422(最小费用最大流)

    题目链接:http://poj.org/problem?id=3422 思路:求从起点到终点走k次获得的最大值,最小费用最大流的应用:将点权转化为边权,需要拆点,边容量为1,费用为该点的点权,表示该点 ...

  2. POJ 2516 最小费用最大流

    每一种货物都是独立的,分成k次最小费用最大流即可! 1: /** 2: 因为e ==0 所以 pe[v] pe[v]^1 是两条相对应的边 3: E[pe[v]].c -= aug; E[pe[v]^ ...

  3. POJ - 2195 最小费用最大流

    题意:每个人到每个房子一一对应,费用为曼哈顿距离,求最小的费用 题解:单源点汇点最小费用最大流,每个人和房子对于建边 #include<map> #include<set> # ...

  4. poj 2195 最小费用最大流模板

    /*Source Code Problem: 2195 User: HEU_daoguang Memory: 1172K Time: 94MS Language: G++ Result: Accept ...

  5. POJ 2135 最小费用最大流 入门题

    Farm Tour Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 19207   Accepted: 7441 Descri ...

  6. poj 2135最小费用最大流

    最小费用最大流问题是经济学和管理学中的一类典型问题.在一个网络中每段路径都有"容量"和"费用"两个限制的条件下,此类问题的研究试图寻找出:流量从A到B,如何选择 ...

  7. poj 3680(最小费用最大流)

    题目链接:http://poj.org/problem?id=3680 思路:因为N<=200,而区间范围为[1,100000],因此需要离散化,去重,然后就是建图了相连两点连边,容量为k,费用 ...

  8. POJ 2135 最小费用最大流

    题目链接 Farm Tour Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 18961   Accepted: 7326 D ...

  9. POJ 2195:Going Home(最小费用最大流)

    http://poj.org/problem?id=2195 题意:有一个地图里面有N个人和N个家,每走一格的花费是1,问让这N个人分别到这N个家的最小花费是多少. 思路:通过这个题目学了最小费用最大 ...

随机推荐

  1. hdu 3308 LCIS 线段树

    昨天热身赛的简单版:LCIS.昨天那题用树链剖分,不知道哪里写错了,所以水了水这题看看合并.更新方式是否正确,发现没错啊.看来应该是在树链剖分求lca时写错了... 题目:给出n个数,有两种操作: 1 ...

  2. Codeforces Round #197 (Div. 2) C,D两题

    开了个小号做,C题一开始看错范围,D题看了半小时才看懂,居然也升到了div1,囧. C - Xenia and Weights 给出一串字符串,第i位如果是1的话,表示有重量为i的砝码,如果有该种砝码 ...

  3. 转: ant condition使用

    评注: 用c语言的方式来,比喻ant...比较好理解 转: http://www.smithfox.com/?e=176 [备忘] Apache Ant中的逻辑判断 [原创链接: http://www ...

  4. [Excel操作]Microsoft Office Excel 不能访问文件

    最近,客户服务器迁移,因操作系统环境变化而引起的的环境问题一堆,遇到的问题并解决方法在“[Excel]操作”类别会体现. Microsoft Office Excel 不能访问文件“C:\\LMSEx ...

  5. 使用ambari搭建Hadoop平台

    1.操作系统 CentoOS Server with GUI(有GUI,有浏览器*ambari基于浏览器*推荐latest stable version)2.分区 默认 + /hadoop3.网络设置 ...

  6. PAT1003——我要通过!

    “答案正确”是自动判题系统给出的最令人欢喜的回复.本题属于PAT的“答案正确”大派送 —— 只要读入的字符串满足下列条件,系统就输出“答案正确”,否则输出“答案错误”. 得到“答案正确”的条件是: 1 ...

  7. 怎么解决tomcat占用8080端口问题图文教程(转)

    亲测有效. 原因:可能是开了多个tomcat 原文网址:http://jingyan.baidu.com/article/1612d5006c3cdae20e1eee04.html  怎么解决tomc ...

  8. raphael画图

    // 在坐标(10,50)创建宽320,高200的画布 var paper = Raphael(10, 50, 320, 200); // 在坐标(x = 50, y = 40)绘制半径为 10 的圆 ...

  9. UI3_UITableViewDelete(多选)

    // AppDelegate.m // UI3_UITableViewDelete(多选) // // Created by zhangxueming on 15/7/14. // Copyright ...

  10. defrag磁盘整理命令

    1: Microsoft 磁盘碎片整理程序 2: 版权所有 (c) 2007 Microsoft Corp. 3: 参数错误. (0x80070057) 4: 描述: 5: 定位并合并本地卷中的碎片文 ...