P1251 餐巾

    • 15通过
    • 95提交
  • 题目提供者该用户不存在
  • 标签网络流贪心
  • 难度提高+/省选-

提交该题 讨论 题解 记录

最新讨论

题目描述

一个餐厅在相继的N天里,第i天需要Ri块餐巾(i=l,2,…,N)。餐厅可以从三种途径获得餐巾。

(1)购买新的餐巾,每块需p分;

(2)把用过的餐巾送到快洗部,洗一块需m天,费用需f分(f<p)。如m=l时,第一天送到快洗部的餐巾第二天就可以使用了,送慢洗的情况也如此。

(3)把餐巾送到慢洗部,洗一块需n天(n>m),费用需s分(s<f)。

在每天结束时,餐厅必须决定多少块用过的餐巾送到快洗部,多少块送慢洗部。在每天开始时,餐厅必须决定是否购买新餐巾及多少,使洗好的和新购的餐巾之和满足当天的需求量Ri,并使N天总的费用最小

输入输出格式

输入格式:

输入文件共3行,第1行为总天数;第2行为每天所需的餐巾块数;第3行为每块餐巾的新购费用p,快洗所需天数m,快洗所需费用f,慢洗所需天数n,慢洗所需费用s。

输出格式:

输出文件共1行为最小的费用。

输入输出样例

输入样例#1:

3
3 2 4
10 1 6 2 3
输出样例#1:

64

说明

N<=2000

ri<=10000000

p,f,s<=10000

时限4s

坑题,老师们都开始出网络流的题了。(不是说noip不考吗?)

本题数据范围较大,建议不会网络流的童鞋先放一放。或者做一下下面数据范围小的。

n<=200,Ri<=50 这个范围的话,暴力加剪枝

评测地址:http://cojs.tk/cogs/problem/problem.php?pid=461

小数据范围AC代码及思路(我同学的,自己懒得再敲一遍了):http://www.cnblogs.com/yanlifneg/p/5753685.html

如果你已经AC了上面数据范围较小的测试,相信自己一样可以AC N<=2000,ri<=10000000 这个范围的测试,那就往下看吧

题解:

在思考这个问题时,一般容易想到从洗的角度去思考,这就必然要对每天的餐巾来源进行分类穷举,当天数较长,每天需求量较大时,穷举的数量级至少为每天的餐巾数之积,程序很难在规定时间内运行出最优解。如果从买的角度去思考这个问题,则该问题就变得十分简单。在确定要买的餐巾数之后,显然这些餐巾购买得越早,被反复利用的可能就越大。也就是说,这些餐巾必须在最早的几天中购买,余下的缺口用洗出来的餐巾来填补,对每天用下来的餐巾,假设全部都送洗,但送洗时不确定其状态,即它们有可能被快洗,有可能被慢洗,也可能不用洗,其状态在今后被选用时再确定。在确定每天的需求时,除去买的,剩下的首先要选用慢洗为好。这种餐巾有多少应用多少,不够再选用快洗出来的餐巾。选用快洗出来的餐巾时,应选用最近的若干天中才快洗出来的餐巾,这样可以保证有更多的餐巾被慢洗出来。这就是我

们的贪心思想。

对所要购买的餐巾数进行穷举,开始时其值为所需用餐巾数之和,当购买量太少而周转不过来时,程序结束。在确定了购买的餐巾总数后,按上述算法构造出最小费用方案,所有的最小费用方案中的最优解即为问题的解。

------------------------------------------------------

上面为标程的“贪心+网络流”的思路

下面说点实在的。具体如何做。

------------------------------------------------------

把每天分为二分图两个集合中的顶点Xi,Yi,建立附加源S汇T。
  1、从S向每个Xi连一条容量为ri,费用为0的有向边。
  2、从每个Yi向T连一条容量为ri,费用为0的有向边。
  3、从S向每个Yi连一条容量为无穷大,费用为p的有向边。
  4、从每个Xi向Xi+1(i+1<=N)连一条容量为无穷大,费用为0的有向边。
  5、从每个Xi向Yi+m(i+m<=N)连一条容量为无穷大,费用为f的有向边。
  6、从每个Xi向Yi+n(i+n<=N)连一条容量为无穷大,费用为s的有向边。

  经过分析可以把每天要用的和用完的分离开处理,建模后就是二分图。二分图X集合中顶点Xi表示第i天用完的餐巾,其数量为ri,所以从S向Xi连接容量为ri的边作为限制。Y集合中每个点Yi则是第i天需要的餐巾,数量为ri,与T连接的边容量作为限制。每天用完的餐巾可以选择留到下一天(Xi->Xi+1),不需要花费,送到快洗部(Xi->Yi+m),费用为f,送到慢洗部(Xi->Yi+n),费用为s。每天需要的餐巾除了刚刚洗好的餐巾,还可能是新购买的(S->Yi),费用为p。

ps:写代码的时候,注意时间复杂度,遍历不好会TLE的。我懒,就懒得写读入优化了。

AC代码:

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
const ll inf=(1LL<<);
const int N=;
int src,dest;
int T,head[N],a[N];
ll dis[N],flow[N];
bool vis[N];
struct node{
int to;
ll cap,cost;
int nxt;
}edge[N<<];
void add(int s,int t,ll c,ll cost){
edge[T]=(node){t,c,cost,head[s]};
head[s]=T++;
edge[T]=(node){s,,-cost,head[t]};
head[t]=T++;
}
int que[N<<],pre[N],fa_edge[N];
bool spfa(){
for(int i=;i<=dest;i++) vis[i]=,dis[i]=inf;
vis[src]=;dis[src]=;
flow[src]=inf;
int h=,t=;
que[t++]=src;
while(h<t){
int k=que[h++];
vis[k]=;
for(int i=head[k];~i;i=edge[i].nxt){
int y=edge[i].to;
if(edge[i].cap&&dis[y]>dis[k]+edge[i].cost){
dis[y]=dis[k]+edge[i].cost;
pre[y]=k;
fa_edge[y]=i;
flow[y]=min(flow[k],edge[i].cap);
if(!vis[y]){
vis[y]=;
que[t++]=y;
}
}
}
}
return (dis[dest]!=inf);
}
ll min_cost(){
ll ans=;
int x;
while(spfa()){
ans+=dis[dest]*flow[dest];
x=dest;
while(x!=src){
edge[fa_edge[x]].cap-=flow[dest];
edge[fa_edge[x]^].cap+=flow[dest];
x=pre[x];
}
}
return ans;
}
int main(){
int t,p,m,f,n,s;
scanf("%d",&t);
for(int i=;i<=t;i++) scanf("%d",&a[i]);
dest=t<<|;src=;
scanf("%d%d%d%d%d",&p,&m,&f,&n,&s);
memset(head,-,sizeof head);
for(int i=;i<=t;i++){
add(src,i,a[i],p);
add(i,dest,a[i],);
add(src,i+t,a[i],);
if(i+m<=t) add(i+t,i+m,inf,f);
if(i+n<=t) add(i+t,i+n,inf,s);
if(i!=t) add(i+t,i+t+,inf,);
}
cout<<min_cost()<<endl;
return ;
}

洛谷P1251 餐巾(网络流)的更多相关文章

  1. 洛谷 P1251 餐巾计划问题(线性规划网络优化)【费用流】

    (题外话:心塞...大部分时间都在debug,拆点忘记加N,总边数算错,数据类型标错,字母写错......) 题目链接:https://www.luogu.org/problemnew/show/P1 ...

  2. 洛谷P1251 餐巾计划问题(费用流)

    传送门 不得不说这题真是思路清奇,真是网络流的一道好题,完全没想到网络流的建图还可以这么建 我们把每一个点拆成两个点,分别表示白天和晚上,白天可以得到干净的餐巾(购买的,慢洗的,快洗的),晚上可以得到 ...

  3. 洛谷P1251 餐巾计划问题(最小费用最大流)

    题意 一家餐厅,第$i$天需要$r_i$块餐巾,每天获取餐巾有三种途径 1.以$p$的费用买 2.以$f$的费用送到快洗部,并在$m$天后取出 3.以$s$的费用送到慢洗部,并在$n$天后取出 问满足 ...

  4. [洛谷P1251]餐巾计划问题

    题目大意:一个餐厅N天,每天需要$r_i$块餐巾.每块餐巾需要p元,每天用过的餐巾变脏,不能直接用.现在有快洗店和慢洗店,快洗店洗餐巾需要m天,每块花费f元:慢洗店洗餐巾需要n天,每块餐巾s元(m & ...

  5. 洛谷 P1251 餐巾计划问题【最小费用最大流】

    建图细节比较多,对于每个点i,拆成i和i',i表示用的餐巾,i'表示脏餐巾,连接: (s,i,r[i],p)表示在这一天买新餐巾 (i,t,r[i],0)表示这一天用了r[i]的餐巾 (s,i+n,r ...

  6. 洛谷 P1251 餐巾计划问题

    题目链接 最小费用最大流. 每天拆成两个点,早上和晚上: 晚上可以获得\(r_i\)条脏毛巾,从源点连一条容量为\(r_i\),费用为0的边. 早上要供应\(r_i\)条毛巾,连向汇点一条容量为\(r ...

  7. [洛谷P3376题解]网络流(最大流)的实现算法讲解与代码

    [洛谷P3376题解]网络流(最大流)的实现算法讲解与代码 更坏的阅读体验 定义 对于给定的一个网络,有向图中每个的边权表示可以通过的最大流量.假设出发点S水流无限大,求水流到终点T后的最大流量. 起 ...

  8. 【洛谷 P1251】 餐巾计划问题 (费用流)

    题目链接 我做的网络流24题里的第一题.. 想是不可能想到的,只能看题解. 首先,我们拆点,将一天拆成晚上和早上,每天晚上会受到脏餐巾(来源:当天早上用完的餐巾,在这道题中可理解为从原点获得),每天早 ...

  9. 洛谷 [P251] 餐巾计划问题

    有上下界的最小费用最大流 可以联想到供求平衡问题,所以我们要拆点做这道题 把每天分为二分图两个集合中的顶点Xi,Yi,建立附加源S汇T. 1.从S向每个Xi连一条容量为ri,费用为0的有向边. 2.从 ...

随机推荐

  1. C#以及Oracle中的上取整、下取整方法

    1.C#中: 上取整——Math.Ceiling(Double),即返回大于或等于指定双精度浮点数的最大整数(也可称为取天板值): eg:  Math.Ceiling(1.01)=2;      Ma ...

  2. ie10中元素超出父元素的宽度时不能自动隐藏

    (从已经死了一次又一次终于挂掉的百度空间人工抢救出来的,发表日期2014-02-21) 今天遇到一个问题,ie10中元素超出父元素的宽度时不能自动隐藏,而其余浏览器却正常显示. 解决方法是,手动给其设 ...

  3. A debugger is already attached

    Today is the last day that all the laptops of winXP OS should be upgrade to WIN7. After updated. whe ...

  4. 在sphinx中应用复杂过滤条件

    一.问题的引入   在sphinx应用中,需要对数据进行复杂的条件过滤,刷选出我们需要的数据.这个过程,等同于mysql查询中的where条件.   但sphinx本身的filter并不能支持复杂的逻 ...

  5. Codeforces Good Bye 2015 C. New Year and Domino 前缀和

    C. New Year and Domino 题目连接: http://www.codeforces.com/contest/611/problem/C Description They say &q ...

  6. Codeforces Round #335 (Div. 2) D. Lazy Student 构造

    D. Lazy Student Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/606/probl ...

  7. [Angular2 Router] CanActivate Route Guard - An Example of An Asynchronous Route Guard

    In this tutorial we are going to learn how we can to configure an can activate route guard in the An ...

  8. 单片机modebus RTU通信实现,採用C语言,可适用于单片机,VC,安卓等

    当前使用的是STM32+ucos_ii编写的,能够移植到安卓以及VC .NET等方便移植使用,採用modebus poll測试过. 仅仅须要改动响应的通信接口就可以,方便多串口使用 //modebus ...

  9. android UI设计时须要注意遵循的设计原则

    1.Android设备屏幕尺寸分布 首先看一下各种屏幕的尺寸和屏幕密度划分,下图是各种屏幕尺寸相应的范围: 从上图能够看出.相应normal尺寸的屏幕范围集中在常见的3到5寸屏之间.large尺寸相应 ...

  10. [原创]SSAS-引用维度与多数据源、多数据源视图引发分区错误

    背景:       最近有个项目,有32家分公司,集团总部需要取这个32家分公司数据做分析,由于每个分公司的数据都比较庞大,所以最终方案是每个分公司一个DW,在cube搭建过程中将每个公司数据作为一个 ...