/*虽然这暴力剪了又剪 改了又改 还是初始的20分...*/
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 2010
using namespace std;
int n,sum,c[maxn],ans,p,t1,t2,c1,c2,f[maxn];
void Dfs(int now,int cost)
{
if(cost>=ans)return;
if(now==n){ans=min(ans,cost);return;}
int a,b,x=;
for(int i=;i<=c[now];i++)
{
b=c[now]-i;a=i;
if(a>c[now+t1]-f[now+t1])a=c[now+t1]-f[now+t1];
if(b>c[now+t2]-f[now+t2])b=c[now+t2]-f[now+t2];
if((a&&now+t1>n)||(b&&now+t2>n))continue;
f[now+t1]+=a;f[now+t2]+=b;
x=max(,c[now+]-f[now+]);
Dfs(now+,cost+x*p+a*c1+b*c2);
f[now+t1]-=a;f[now+t2]-=b;
}
}
int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)
scanf("%d",&c[i]),sum+=c[i];
scanf("%d%d%d%d%d",&p,&t1,&c1,&t2,&c2);
ans=sum*p;Dfs(,c[]*p);
printf("%d\n",ans);
return ;
}
/*
标签是网络流 然而并不会
贪心的复杂度是 O(Σci)ci为每天的需求
比较大......
如果暴力的话 每天的状态需要枚举那几个来自慢洗的 那几个来自快洗的 那几个来自买的
复杂度高到上天....
我们可以从买的角度考虑 枚举一共买多少 尽量先给前面 这样后面可供使用的就多
当买了不够了的话 就用洗出来的补
对于i时刻 显然优先用慢洗出来的补更便宜 慢洗的用完了在用快洗的
这里用快洗的时候要优先使用隔得近的 保证后面的状态可以得到更多的慢洗的
then 就是代码了
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 2010
using namespace std;
int n,p,sum,mxx,c1,c2,t1,t2,c[maxn],Zang[maxn],ans,falg;
int cnow,nump,ci,num1,num2;
int main()
{
//freopen("napkin.in","r",stdin);
//freopen("napkin.out","w",stdout);
scanf("%d",&n);
for(int i=;i<=n;i++)
scanf("%d",&c[i]),sum+=c[i],mxx=max(mxx,c[i]);
scanf("%d%d%d%d%d",&p,&t1,&c1,&t2,&c2);
ans=sum*p;
for(int k=sum-;k>=mxx;k--)//枚举一共买多少
{
cnow=k*p;nump=k;
for(int i=;i<=n;i++)
{
if(nump>=c[i]){nump-=c[i];Zang[i]=c[i];}//前面的优先买 提前拿去洗 更优
else
{
ci=c[i]-nump;//除了买来的 还需要几个
num1=num2=nump=;
for(int j=;j<=i-t2;j++)//慢洗的优先
{
if(ci>num2)
{
num2+=Zang[j];Zang[j]=;
if(num2>=ci)
{
Zang[j]=num2-ci;num2=ci;
break;
}
}
}
ci-=num2;//出去慢洗的
if(ci)//如果不够
{
for(int j=i-t1;j>=;j--)//快洗先用隔得最近的
{
if(ci>num1)
{
num1+=Zang[j];Zang[j]=;
if(num1>=ci)
{
Zang[j]=num1-ci;num1=ci;
break;
}
}
}
}
ci-=num1;
if(ci){falg=;break;}//购买量太少而周转不过来时
cnow+=num1*c1+num2*c2;Zang[i]=c[i];
}
}
if(falg)break;
else ans=min(ans,cnow);
}
printf("%d\n",ans);
return ;
}

cogs 餐巾 461(贪心)的更多相关文章

  1. 餐巾(cogs 461)

    [问题描述] 一个餐厅在相继的N天里,第i天需要Ri块餐巾(i=l,2,…,N).餐厅可以从三种途径获得餐巾. (1)购买新的餐巾,每块需p分: (2)把用过的餐巾送到快洗部,洗一块需m天,费用需f分 ...

  2. [网络流24题]餐巾(cogs 461)

    [问题描述] 一个餐厅在相继的N天里,第i天需要Ri块餐巾(i=l,2,-,N).餐厅可以从三种途径获得餐巾. (1)购买新的餐巾,每块需p分: (2)把用过的餐巾送到快洗部,洗一块需m天,费用需f分 ...

  3. 【COGS 461】[网络流24题] 餐巾 最小费用最大流

    既然是最小费用最大流我们就用最大流来限制其一定能把每天跑满,那么把每个表示天的点向T连流量为其所需餐巾,费用为0的边,然后又与每天的餐巾对于买是无限制的因此从S向每个表示天的点连流量为INF,费用为一 ...

  4. Cogs 461. [网络流24题] 餐巾(费用流)

    [网络流24题] 餐巾 ★★★ 输入文件:napkin.in 输出文件:napkin.out 简单对比 时间限制:5 s 内存限制:128 MB [问题描述] 一个餐厅在相继的N天里,第i天需要Ri块 ...

  5. P4480-[BJWC2018]餐巾计划问题【三分,贪心】

    正题 题目链接:https://www.luogu.com.cn/problem/P4480 题目大意 \(n\)天,第\(i\)天需要\(a_i\)个餐巾. 每个餐巾价格为\(p\),使用完后有两种 ...

  6. 【COGS】714. USACO 1.3.2混合牛奶(贪心+水题)

    http://cojs.tk/cogs/problem/problem.php?pid=714 在hzwer的刷题记录上,默默地先跳过2题T_T...求凸包和期望的..T_T那是个啥..得好好学习 看 ...

  7. 贪心(数据结构):COGS 468. [NOI2010]超级钢琴

    ★★★☆   输入文件:piano.in   输出文件:piano.out   简单对比 时间限制:2 s   内存限制:512 MB 超级钢琴 [问题描述] 小Z是一个小有名气的钢琴家,最近C博士送 ...

  8. 洛谷P1251 餐巾(网络流)

    P1251 餐巾 15通过 95提交 题目提供者该用户不存在 标签网络流贪心 难度提高+/省选- 提交该题 讨论 题解 记录 最新讨论 为什么我全部10个测试点都对… 题目描述 一个餐厅在相继的N天里 ...

  9. [联赛可能考到]图论相关算法——COGS——联赛试题预测

    COGS图论相关算法 最小生成树 Kruskal+ufs int ufs(int x) { return f[x] == x ? x : f[x] = ufs(f[x]); } int Kruskal ...

随机推荐

  1. linux svn使用

    SVN是一种版本管理系统,前身是CVS,是开源软件的基石.即使在沟通充分的情况下,多人维护同一份源代码的一定也会出现混乱的情况,版本管理系统就是为了解决这些问题. SVN中的一些概念 : a. rep ...

  2. baseadapter.getItemId的使用方法:实现listview筛选、动态删除

    转载:http://www.lai18.com/content/1631131.html 这里的listview筛选是指listview的adapter实现filter来过滤数据. “动态删除&quo ...

  3. 蓝桥杯--Quadratic Equation

    蓝桥杯--Quadratic Equation 问题描述 求解方程ax2+bx+c=0的根.要求a, b, c由用户输入,并且可以为任意实数. 输入格式:输入只有一行,包括三个系数,之间用空格格开. ...

  4. mac ide

    常用IDE xcode sublime text eclipse xampp + phpstorm sql客户端:sequel pro 虚拟机:parallels desktop sftp客户端:Cy ...

  5. Android中图表AChartEngine学习使用与例子

    很多时候项目中我们需要对一些统计数据进行绘制表格,更多直观查看报表分析结果.基本有以下几种方法: 1:可以进行android  api进行draw这样的话,效率比较低 2:使用开源绘表引擎,这样效率比 ...

  6. Android Service AIDL 远程调用服务 【简单音乐播放实例】

    Android Service是分为两种: 本地服务(Local Service): 同一个apk内被调用 远程服务(Remote Service):被另一个apk调用 远程服务需要借助AIDL来完成 ...

  7. Qt4.8.6+mingw+Qgis2.4.0基于QGis的二次开发

    关于QGis的二次开发,大致看了一下,基本都是在VC+QT的环境下做环境部署,并且QGis的版本号很老.在mingw下直接开发搭建好开发环境的样例少之又少.基于最新的Qgis2.4.0版本号做了对应的 ...

  8. Android 滑动效果基础篇(三)—— Gallery仿图像集浏览

    Android系统自带一个Gallery浏览图片的应用,通过手指拖动时能够非常流畅的显示图片,用户交互和体验都很好. 本示例就是通过Gallery和自定义的View,模仿实现一个仿Gallery图像集 ...

  9. [Effective C++ --031]将文件间的编译依存关系降至最低

    引言:编译时间成本 在项目中我们都会碰到修改既存类的情况:某个class实现文件做了些轻微改变,修改的不是接口,而是实现,而且只改private成分. 重新build这个程序,并预计只花数秒就好,当按 ...

  10. LeetCode: Reverse Words in a String:Evaluate Reverse Polish Notation

    LeetCode: Reverse Words in a String:Evaluate Reverse Polish Notation Evaluate the value of an arithm ...