UVA-11613 Acme Corporation (最大费用最大流+拆点)
题目大意:有一种商品X,其每每单位存放一个月的代价I固定。并且已知其每月的最大生产量、生产每单位的的代价、最大销售量和销售单价,还已知每个月生产的X能最多能存放的时间(以月为单位)。问只考虑前m个月,最多能获得多少利润。
题目分析:增加源点s和汇点t,将每一个月视作一个节点。建立图模型如下:将每一个节点拆成两个,即将v拆成v和v1,从s向所有的v连一条弧,容量为该月最大生产量,费用为该月的单位生产代价;然后从所有的v1出发连一条弧向t,容量为该月最大销售量,费用为销售单价的相反数;最后,从v出发向所有它能存放到的月数u对应的u1连一条弧,容量为正无穷大,费用为I*(u-v)。对该模型求最小费用最大流,显然,这里对最小费用取相反数便的最大利润。
代码如下:
- # include<iostream>
- # include<cstdio>
- # include<cmath>
- # include<string>
- # include<vector>
- # include<list>
- # include<set>
- # include<map>
- # include<queue>
- # include<cstring>
- # include<algorithm>
- using namespace std;
- # define LL long long
- # define REP(i,s,n) for(int i=s;i<n;++i)
- # define CL(a,b) memset(a,b,sizeof(a))
- # define CLL(a,b,n) fill(a,a+n,b)
- const double inf=1e30;
- const int INF=1<<30;
- const int N=300;
- struct Edge
- {
- int fr,to;
- LL cap,flow,cost;
- Edge(int _fr,int _to,LL _cap,LL _flow,LL _cost):fr(_fr),to(_to),cap(_cap),flow(_flow),cost(_cost){}
- };
- vector<Edge>edges;
- vector<int>G[N];
- int p[N],inq[N],n,I;
- LL a[N],d[N];
- void init()
- {
- edges.clear();
- REP(i,0,n) G[i].clear();
- }
- void addEdge(int fr,int to,LL cap,LL cost)
- {
- edges.push_back(Edge(fr,to,cap,0,cost));
- edges.push_back(Edge(to,fr,0,0,-cost));
- int m=edges.size();
- G[fr].push_back(m-2);
- G[to].push_back(m-1);
- }
- bool BellmanFord(int s,int t,LL &flow,LL &cost)
- {
- CL(inq,0);
- CLL(d,INF,n);
- d[s]=0,inq[s]=1,p[s]=0,a[s]=INF;
- queue<int>q;
- q.push(s);
- while(!q.empty()){
- int u=q.front();
- q.pop();
- inq[u]=0;
- REP(i,0,G[u].size()){
- Edge &e=edges[G[u][i]];
- if(e.cap>e.flow&&d[e.to]>d[u]+e.cost){
- d[e.to]=d[u]+e.cost;
- p[e.to]=G[u][i];
- a[e.to]=min(a[u],e.cap-e.flow);
- if(!inq[e.to]){
- q.push(e.to);
- inq[e.to]=1;
- }
- }
- }
- }
- if(d[t]>0) return false;
- flow+=(LL)a[t];
- cost+=(LL)d[t]*(LL)a[t];
- for(int u=t;u!=s;u=edges[p[u]].fr){
- edges[p[u]].flow+=a[t];
- edges[p[u]^1].flow-=a[t];
- }
- return true;
- }
- LL Mincost(int s,int t)
- {
- LL flow=0,cost=0;
- while(BellmanFord(s,t,flow,cost));
- return cost;
- }
- struct X
- {
- int m,n,p,s,E;
- };
- X x[105];
- int main()
- {
- int T,m,s,t,cas=0;
- scanf("%d",&T);
- while(T--)
- {
- scanf("%d%d",&m,&I);
- n=2*m+2;
- s=0,t=2*m+1;
- init();
- 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);
- REP(i,1,m+1){
- addEdge(0,2*i-1,x[i].n,x[i].m);
- addEdge(2*i,t,x[i].s,-x[i].p);
- }
- REP(i,1,m+1) REP(j,i,min(i+x[i].E,m)+1)
- addEdge(2*i-1,2*j,INF,I*(j-i));
- printf("Case %d: %lld\n",++cas,-Mincost(s,t));
- }
- return 0;
- }
UVA-11613 Acme Corporation (最大费用最大流+拆点)的更多相关文章
- UVa 1658 - Admiral(最小费用最大流 + 拆点)
链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- UVA 11613 Acme Corporation(不固定流量的最小费用流)
题意好长....变量好多.... 增加源点跟汇点.然后将每个月份看成一个点,然后拆成两个点u 跟 u+n. 从s向每个u连一条<n[u], m[i]>的弧,表示最多生产量及价值. 从每个u ...
- UVa 10806 Dijkstra,Dijkstra(最小费用最大流)
裸的费用流.往返就相当于从起点走两条路到终点. 按题意建图,将距离设为费用,流量设为1.然后增加2个点,一个连向节点1,流量=2,费用=0;结点n连一条同样的弧,然后求解最小费用最大流.当且仅当最大流 ...
- UVA - 1658 Admiral (最小费用最大流)
最短路对应费用,路径数量对应流量.为限制点经过次数,拆点为边.跑一次流量为2的最小费用最大流. 最小费用最大流和最大流EK算法是十分相似的,只是把找增广路的部分换成了求费用的最短路. #include ...
- BZOJ-1070 修车 最小费用最大流+拆点+略坑建图
1070: [SCOI2007]修车 Time Limit: 1 Sec Memory Limit: 162 MB Submit: 3624 Solved: 1452 [Submit][Status] ...
- UVa 1658 海军上将(最小费用最大流)
https://vjudge.net/problem/UVA-1658 题意: 给出一个v个点e条边的有向加权图,求1~v的两条不相交(除了起点和终点外公共点)的路径,使得权和最小. 思路:把2到v- ...
- uva 1658 Admiral 【 最小费用最大流 】
拆点,每个点拆成 i,i' 在i 和i‘之间连一条费用为0,容量为1的边,就可以保证每个点只经过一次 特殊的点,1和n之间,,,n和2*n之间连一条费用为0,容量为2的边,可以求出两条路径 #incl ...
- BZOJ-1877 晨跑 最小费用最大流+拆点
其实我是不想做这种水题的QWQ,没办法,剧情需要 1877: [SDOI2009]晨跑 Time Limit: 4 Sec Memory Limit: 64 MB Submit: 1704 Solve ...
- BZOJ-2324 营救皮卡丘 最小费用可行流+拆下界+Floyd预处理
准备一周多的期末,各种爆炸,回来后状态下滑巨快...调了一晚上+80%下午 2324: [ZJOI2011]营救皮卡丘 Time Limit: 10 Sec Memory Limit: 256 MB ...
随机推荐
- redis缓存数据架构实战
redis命令参考:http://redisdoc.com/ 与memcache对比 redis安装配置 yum安装 yum -y install redis 源码安装 PS:make报错**问题:* ...
- 徐州网络赛A-Hard To Prepare【dp】【位运算】【快速幂】
After Incident, a feast is usually held in Hakurei Shrine. This time Reimu asked Kokoro to deliver a ...
- python提取相对路径
原理: 用绝对路径,截断根目录的路径,就得到了相对路径. 代码 方法1:字符串替换(用字符串函数)推荐 import os print('==========1===========') abspat ...
- 纯css3加载动画
<!DOCTYPE html><html> <head> <meta charset="utf-8"> <meta name= ...
- mysql 数据操作 单表查询 group by 聚合函数 没有group by情况下
聚合函数只能用在组里使用 #没有group by 则默认算作一组 取出所有员工的最高工资 mysql> select max(salary) from employee; +---------- ...
- Java压缩多个文件并导出
controller层: /** * 打包压缩下载文件 */ @RequestMapping(value = "/downLoadZipFile") public void dow ...
- 程序员:统治世界or修复bug?
程序员:统治世界or修复bug? 时至今日,我们依然生活在一个市场和技术受到高度崇拜的世界里,但是历史演化的规律提醒着我们:当一个东西开始成为社会崇拜的对象时,其中暗藏的不利因素将悄然的进行着.有人认 ...
- 1 :2 Strust2—Demo
=============================================================== Demo基础包:
- link标签 rel="stylesheet"
首先,link标签是用于当前文档引用外部文档的,其次,这个标签的rel属性用于设置对象和链接目的间的关系,说白了就是指明你链进来的对象是个什么东西的,具体的值及其所表示的关系如下:Alternate: ...
- VS2010/MFC编程入门之二十(常用控件:静态文本框)
上一节鸡啄米讲了颜色对话框之后,关于对话框的使用和各种通用对话框的介绍就到此为止了.从本节开始鸡啄米将讲解各种常用控件的用法.常用控件主要包括:静态文本框.编辑框.单选按钮.复选框.分组框.列表框.组 ...