[codevs_1237]餐巾计划问题
题目描述
一个餐厅在相继的N 天里,每天需用的餐巾数不尽相同。假设第i天需要ri块餐巾(i=1,2,…,N)。餐厅可以购买新的餐巾,每块餐巾的费用为p分;或者把旧餐巾送到快洗部,洗一块需m天,其费用为f 分;或者送到慢洗部,洗一块需n 天(n>m),其费用为s<f 分。每天结束时,餐厅必须决定将多少块脏的餐巾送到快洗部,多少块餐巾送到慢洗部,以及多少块保存起来延期送洗。但是每天洗好的餐巾和购买的新餐巾数之和,要满足当天的需求量。
试设计一个算法为餐厅合理地安排好N
天中餐巾使用计划,使总的花费最小。
输入
文件第1 行有6 个正整数N,p,m,f,n,s。N 是要安排餐巾使用计划的天数;p
是每块新餐巾的费用;m 是快洗部洗一块餐巾需用天数;f
是快洗部洗一块餐巾需要的费用;n是慢洗部洗一块餐巾需用天数;s是慢洗部洗一块餐巾需要的费用。
接下来的N 行是餐厅在相继的N
天里,每天需用的餐巾数。
输出
输出仅有一个整数,为餐厅在相继的N 天里使用餐巾的最小总花费。
样例输入
3 10 2 3 3 2
5
6
7
样例输出
145 费用流。但是如何建图呢。把每天拆成两个点,i为每天有的干净餐巾数,i+N为每天有的脏餐巾数,建一个超级源点S,一个超级汇点T 把S向i连一条容量为INF,费用为p的边。表示每天可以买无限块餐巾,一条餐巾p分
把i向T连一条容量为ri,费用为0的边。表示每天需要ri块餐巾
把S向i+N连一条容量为ri,费用为0的边。表示每天会用脏ri块餐巾
把i+N向i+m连一条容量为INF,费用为f的边。表示每天可以去快洗部清洗无限块餐巾,耗时m天,一条餐巾需f分
把i+N向i+n连一条容量为INF,费用为s的边。表示每天可以去慢洗部清洗无限块餐巾,耗时n天,一条餐巾需s分
把i+N向i+N+1连一条容量为INF,费用为0的边。表示每天可以把未清洗的餐巾留到下一天
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int inq[],d[],h[],q[],from[],head,tail,k=,INF=,ans=,r[];
struct data{
int to,cap,cost,next;
}g[];
void add(int from,int to,int cap,int cost)
{
g[++k].next=h[from];h[from]=k;g[k].to=to;g[k].cap=cap;g[k].cost=cost;
g[++k].next=h[to];h[to]=k;g[k].to=from;g[k].cap=;g[k].cost=-cost;
}
bool spfa(int s,int t)
{
memset(inq,,sizeof(inq));
memset(d,/,sizeof(d));INF=d[];
d[s]=;inq[s]=;head=tail=;q[tail++]=s;
while(head<=tail)
{
int u=q[head++];inq[u]=;
for(int i=h[u];i;i=g[i].next)
{
if(g[i].cap&&d[u]+g[i].cost<d[g[i].to])
{
d[g[i].to]=d[u]+g[i].cost;from[g[i].to]=i;
if(!inq[g[i].to])
{
if(d[g[i].to]<d[q[head]])q[--head]=g[i].to;
else q[tail++]=g[i].to;inq[g[i].to]=;
}
}
}
}
if(d[t]==INF)return false;
return true;
}
void mcf(int t)
{
int minn=INF;
for(int i=from[t];i;i=from[g[i^].to])minn=min(minn,g[i].cap);
for(int i=from[t];i;i=from[g[i^].to])g[i].cap-=minn,g[i^].cap+=minn,ans+=minn*g[i].cost;
}
int main()
{
int N,p,m,f,n,s;scanf("%d%d%d%d%d%d",&N,&p,&m,&f,&n,&s);
for(int i=;i<=N;i++)
{
scanf("%d",&r[i]);
add(*N+,i,INF,p);add(i,*N+,r[i],);add(*N+,i+N,r[i],);
if(i+m<=N)add(i+N,i+m,INF,f);
if(i+n<=N)add(i+N,i+n,INF,s);
if(i+<=N)add(i+N,i+N+,INF,);
}
while(spfa(*N+,*N+))mcf(*N+);
printf("%d",ans);return ;
}
[codevs_1237]餐巾计划问题的更多相关文章
- P1251 餐巾计划问题
P1251 餐巾计划问题 题目描述 一个餐厅在相继的 N 天里,每天需用的餐巾数不尽相同.假设第 iii 天需要 rir_iri块餐巾( i=1,2,...,N).餐厅可以购买新的餐巾,每块餐巾的费 ...
- LibreOJ #6008. 「网络流 24 题」餐巾计划 最小费用最大流 建图
#6008. 「网络流 24 题」餐巾计划 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: 匿名 提交提交记录统计讨论测试数据 题目描述 ...
- Libre 6008 「网络流 24 题」餐巾计划 (网络流,最小费用最大流)
Libre 6008 「网络流 24 题」餐巾计划 (网络流,最小费用最大流) Description 一个餐厅在相继的N天里,第i天需要Ri块餐巾(i=l,2,-,N).餐厅可以从三种途径获得餐巾. ...
- 洛谷 P1251 餐巾计划问题(线性规划网络优化)【费用流】
(题外话:心塞...大部分时间都在debug,拆点忘记加N,总边数算错,数据类型标错,字母写错......) 题目链接:https://www.luogu.org/problemnew/show/P1 ...
- BZOJ1229 & 洛谷2917:[USACO2008 NOV]toy 玩具 & 洛谷4480:[BJWC2018]餐巾计划问题——题解
标题很长emmm…… [USACO2008 NOV]toy 玩具 https://www.luogu.org/problemnew/show/P2917 https://www.lydsy.com/J ...
- 初识费用流 模板(spfa+slf优化) 餐巾计划问题
今天学习了最小费用最大流,是网络流算法之一.可以对于一个每条边有一个容量和一个费用(即每单位流的消耗)的图指定一个源点和汇点,求在从源点到汇点的流量最大的前提下的最小费用. 这里讲一种最基础也是最好掌 ...
- AC日记——餐巾计划问题 洛谷 P1084
餐巾计划问题 思路: 氧气优化水过: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 4005 #define ...
- LOJ #6008. 「网络流 24 题」餐巾计划
#6008. 「网络流 24 题」餐巾计划 题目描述 一个餐厅在相继的 n nn 天里,每天需用的餐巾数不尽相同.假设第 i ii 天需要 ri r_iri 块餐巾.餐厅可以购买新的餐巾,每块餐 ...
- [luogu_P1251][LOJ#6008]「网络流 24 题」餐巾计划
[luogu_P1251][LOJ#6008]「网络流 24 题」餐巾计划 试题描述 一个餐厅在相继的 \(N\) 天里,第 \(i\) 天需要 \(R_i\) 块餐巾 \((i=l,2,-,N)\) ...
随机推荐
- python文件操作练习之文件备份
文件备份 ## 文件备份 # 打开文件 def backup(file1, file2): with open(file1, 'rb') as f1,\ open(file2, 'wb') as f2 ...
- Hbase运维参考(项目)
1 Hbase日常运维 1.1 监控Hbase运行状况 1.1.1 操作系统 1.1.1.1 IO 群集网络IO,磁盘IO,HDFS IO IO越大说明文件读写操作越多.当IO突然增加时,有可能:1. ...
- 2.ifconfig
转载http://www.cnblogs.com/peida/archive/2013/02/27/2934525.html 许多windows非常熟悉ipconfig命令行工具,它被用来获取网络接口 ...
- Java课程目录
Java课程目录 1 年前 大家收藏一下这篇文章,这是所有课程的目录. 第一周: 第一课:进制及计算机表示 第二课:进制习题课,进一步介绍进制的知识 第三节课:Java语言的品味(一),通过stati ...
- IIS 部署网站--浏览--“该页无法显示”
解决办法: 打开IIS管理器--web站点(网站)--右键点击对应的站点--属性--主目录--执行权限改为(脚本和和执行文件) 点击“应用”--确定. 重启一下站点,OK.
- 【Deep Learning】林轩田机器学习技法
这节课的题目是Deep learning,个人以为说的跟Deep learning比较浅,跟autoencoder和PCA这块内容比较紧密. 林介绍了deep learning近年来受到了很大的关注: ...
- Java基础-5运算符
一).算数运算符: 算术运算符的功能是做各种算术运算,其操作数可以是字符型.整型或浮点型数据. 运算符 运算 示例 结果 备注 + 加 5+5 10 - 减 4-2 2 * 乘 2*3 6 既 ...
- 用Python实现基于Hadoop Stream的mapreduce任务
用Python实现基于Hadoop Stream的mapreduce任务 因为Hadoop Stream的存在,使得任何支持读写标准数据流的编程语言实现map和reduce操作成为了可能. 为了方便测 ...
- python作业:购物车(第二周)
一.作业需求: 1.启动程序后,输入用户名密码后,如果是第一次登录,让用户输入工资,然后打印商品列表 2.允许用户根据商品编号购买商品 3.用户选择商品后,检测余额是否够,够就直接扣款,不够就提醒 4 ...
- lo口环路问题分析
流程如下,collecter抓取网卡lo和wlan0数据,其中lo口无数据,wlan0是笔记本上网网口,然后按自定义协议把数据包通过lo口发给后端dispatch进行分发! 这种模式下,抓包程序每经过 ...