题目大意:有一种商品X,其每每单位存放一个月的代价I固定。并且已知其每月的最大生产量、生产每单位的的代价、最大销售量和销售单价,还已知每个月生产的X能最多能存放的时间(以月为单位)。问只考虑前m个月,最多能获得多少利润。

题目分析:增加源点s和汇点t,将每一个月视作一个节点。建立图模型如下:将每一个节点拆成两个,即将v拆成v和v1,从s向所有的v连一条弧,容量为该月最大生产量,费用为该月的单位生产代价;然后从所有的v1出发连一条弧向t,容量为该月最大销售量,费用为销售单价的相反数;最后,从v出发向所有它能存放到的月数u对应的u1连一条弧,容量为正无穷大,费用为I*(u-v)。对该模型求最小费用最大流,显然,这里对最小费用取相反数便的最大利润。

代码如下:

  1. # include<iostream>
  2. # include<cstdio>
  3. # include<cmath>
  4. # include<string>
  5. # include<vector>
  6. # include<list>
  7. # include<set>
  8. # include<map>
  9. # include<queue>
  10. # include<cstring>
  11. # include<algorithm>
  12. using namespace std;
  13.  
  14. # define LL long long
  15. # define REP(i,s,n) for(int i=s;i<n;++i)
  16. # define CL(a,b) memset(a,b,sizeof(a))
  17. # define CLL(a,b,n) fill(a,a+n,b)
  18.  
  19. const double inf=1e30;
  20. const int INF=1<<30;
  21. const int N=300;
  22.  
  23. struct Edge
  24. {
  25. int fr,to;
  26. LL cap,flow,cost;
  27. Edge(int _fr,int _to,LL _cap,LL _flow,LL _cost):fr(_fr),to(_to),cap(_cap),flow(_flow),cost(_cost){}
  28. };
  29. vector<Edge>edges;
  30. vector<int>G[N];
  31. int p[N],inq[N],n,I;
  32. LL a[N],d[N];
  33.  
  34. void init()
  35. {
  36. edges.clear();
  37. REP(i,0,n) G[i].clear();
  38. }
  39.  
  40. void addEdge(int fr,int to,LL cap,LL cost)
  41. {
  42. edges.push_back(Edge(fr,to,cap,0,cost));
  43. edges.push_back(Edge(to,fr,0,0,-cost));
  44. int m=edges.size();
  45. G[fr].push_back(m-2);
  46. G[to].push_back(m-1);
  47. }
  48.  
  49. bool BellmanFord(int s,int t,LL &flow,LL &cost)
  50. {
  51. CL(inq,0);
  52. CLL(d,INF,n);
  53. d[s]=0,inq[s]=1,p[s]=0,a[s]=INF;
  54.  
  55. queue<int>q;
  56. q.push(s);
  57. while(!q.empty()){
  58. int u=q.front();
  59. q.pop();
  60. inq[u]=0;
  61. REP(i,0,G[u].size()){
  62. Edge &e=edges[G[u][i]];
  63. if(e.cap>e.flow&&d[e.to]>d[u]+e.cost){
  64. d[e.to]=d[u]+e.cost;
  65. p[e.to]=G[u][i];
  66. a[e.to]=min(a[u],e.cap-e.flow);
  67. if(!inq[e.to]){
  68. q.push(e.to);
  69. inq[e.to]=1;
  70. }
  71. }
  72. }
  73. }
  74. if(d[t]>0) return false;
  75. flow+=(LL)a[t];
  76. cost+=(LL)d[t]*(LL)a[t];
  77. for(int u=t;u!=s;u=edges[p[u]].fr){
  78. edges[p[u]].flow+=a[t];
  79. edges[p[u]^1].flow-=a[t];
  80. }
  81. return true;
  82. }
  83.  
  84. LL Mincost(int s,int t)
  85. {
  86. LL flow=0,cost=0;
  87. while(BellmanFord(s,t,flow,cost));
  88. return cost;
  89. }
  90.  
  91. struct X
  92. {
  93. int m,n,p,s,E;
  94. };
  95. X x[105];
  96.  
  97. int main()
  98. {
  99. int T,m,s,t,cas=0;
  100. scanf("%d",&T);
  101. while(T--)
  102. {
  103. scanf("%d%d",&m,&I);
  104. n=2*m+2;
  105. s=0,t=2*m+1;
  106. init();
  107. REP(i,1,m+1) scanf("%d%d%d%d%d",&x[i].m,&x[i].n,&x[i].p,&x[i].s,&x[i].E);
  108. REP(i,1,m+1){
  109. addEdge(0,2*i-1,x[i].n,x[i].m);
  110. addEdge(2*i,t,x[i].s,-x[i].p);
  111. }
  112. REP(i,1,m+1) REP(j,i,min(i+x[i].E,m)+1)
  113. addEdge(2*i-1,2*j,INF,I*(j-i));
  114. printf("Case %d: %lld\n",++cas,-Mincost(s,t));
  115. }
  116. return 0;
  117. }

  

UVA-11613 Acme Corporation (最大费用最大流+拆点)的更多相关文章

  1. UVa 1658 - Admiral(最小费用最大流 + 拆点)

    链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  2. UVA 11613 Acme Corporation(不固定流量的最小费用流)

    题意好长....变量好多.... 增加源点跟汇点.然后将每个月份看成一个点,然后拆成两个点u 跟 u+n. 从s向每个u连一条<n[u], m[i]>的弧,表示最多生产量及价值. 从每个u ...

  3. UVa 10806 Dijkstra,Dijkstra(最小费用最大流)

    裸的费用流.往返就相当于从起点走两条路到终点. 按题意建图,将距离设为费用,流量设为1.然后增加2个点,一个连向节点1,流量=2,费用=0;结点n连一条同样的弧,然后求解最小费用最大流.当且仅当最大流 ...

  4. UVA - 1658 Admiral (最小费用最大流)

    最短路对应费用,路径数量对应流量.为限制点经过次数,拆点为边.跑一次流量为2的最小费用最大流. 最小费用最大流和最大流EK算法是十分相似的,只是把找增广路的部分换成了求费用的最短路. #include ...

  5. BZOJ-1070 修车 最小费用最大流+拆点+略坑建图

    1070: [SCOI2007]修车 Time Limit: 1 Sec Memory Limit: 162 MB Submit: 3624 Solved: 1452 [Submit][Status] ...

  6. UVa 1658 海军上将(最小费用最大流)

    https://vjudge.net/problem/UVA-1658 题意: 给出一个v个点e条边的有向加权图,求1~v的两条不相交(除了起点和终点外公共点)的路径,使得权和最小. 思路:把2到v- ...

  7. uva 1658 Admiral 【 最小费用最大流 】

    拆点,每个点拆成 i,i' 在i 和i‘之间连一条费用为0,容量为1的边,就可以保证每个点只经过一次 特殊的点,1和n之间,,,n和2*n之间连一条费用为0,容量为2的边,可以求出两条路径 #incl ...

  8. BZOJ-1877 晨跑 最小费用最大流+拆点

    其实我是不想做这种水题的QWQ,没办法,剧情需要 1877: [SDOI2009]晨跑 Time Limit: 4 Sec Memory Limit: 64 MB Submit: 1704 Solve ...

  9. BZOJ-2324 营救皮卡丘 最小费用可行流+拆下界+Floyd预处理

    准备一周多的期末,各种爆炸,回来后状态下滑巨快...调了一晚上+80%下午 2324: [ZJOI2011]营救皮卡丘 Time Limit: 10 Sec Memory Limit: 256 MB ...

随机推荐

  1. redis缓存数据架构实战

    redis命令参考:http://redisdoc.com/ 与memcache对比 redis安装配置 yum安装 yum -y install redis 源码安装 PS:make报错**问题:* ...

  2. 徐州网络赛A-Hard To Prepare【dp】【位运算】【快速幂】

    After Incident, a feast is usually held in Hakurei Shrine. This time Reimu asked Kokoro to deliver a ...

  3. python提取相对路径

    原理: 用绝对路径,截断根目录的路径,就得到了相对路径. 代码 方法1:字符串替换(用字符串函数)推荐 import os print('==========1===========') abspat ...

  4. 纯css3加载动画

    <!DOCTYPE html><html> <head> <meta charset="utf-8"> <meta name= ...

  5. mysql 数据操作 单表查询 group by 聚合函数 没有group by情况下

    聚合函数只能用在组里使用 #没有group by 则默认算作一组 取出所有员工的最高工资 mysql> select max(salary) from employee; +---------- ...

  6. Java压缩多个文件并导出

    controller层: /** * 打包压缩下载文件 */ @RequestMapping(value = "/downLoadZipFile") public void dow ...

  7. 程序员:统治世界or修复bug?

    程序员:统治世界or修复bug? 时至今日,我们依然生活在一个市场和技术受到高度崇拜的世界里,但是历史演化的规律提醒着我们:当一个东西开始成为社会崇拜的对象时,其中暗藏的不利因素将悄然的进行着.有人认 ...

  8. 1 :2 Strust2—Demo

    =============================================================== Demo基础包:

  9. link标签 rel="stylesheet"

    首先,link标签是用于当前文档引用外部文档的,其次,这个标签的rel属性用于设置对象和链接目的间的关系,说白了就是指明你链进来的对象是个什么东西的,具体的值及其所表示的关系如下:Alternate: ...

  10. VS2010/MFC编程入门之二十(常用控件:静态文本框)

    上一节鸡啄米讲了颜色对话框之后,关于对话框的使用和各种通用对话框的介绍就到此为止了.从本节开始鸡啄米将讲解各种常用控件的用法.常用控件主要包括:静态文本框.编辑框.单选按钮.复选框.分组框.列表框.组 ...