/*虽然这暴力剪了又剪 改了又改 还是初始的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. Rop 文件上传解决思路

    由于服务请求报文是一个文本,无法直接传送二进制的文件内容,因此必须采用某种转换机制将二进制的文件内容转换为字符串.Rop 采用如下的方式对上传文件进行编码:<fileType>@<B ...

  2. Codeforces Round #257 (Div. 1) C. Jzzhu and Apples (素数筛)

    题目链接:http://codeforces.com/problemset/problem/449/C 给你n个数,从1到n.然后从这些数中挑选出不互质的数对最多有多少对. 先是素数筛,显然2的倍数的 ...

  3. CodeForces 589J Cleaner Robot (DFS,或BFS)

    题意:给定n*m的矩阵,一个机器人从一个位置,开始走,如果碰到*或者边界,就顺时针旋转,接着走,问你最后机器人最多能走过多少格子. 析:这个题主要是题意读的不大好,WA了好几次,首先是在*或者边界才能 ...

  4. C++中用二维数组传参时形参该怎样写[转]

    二维数组的存储方式是和一维数组没什么区别,但是用二维数组做参数,它的形参该怎样写? 要注意的是:函数中的形参其实就相当于一个声明,并不产生内存分配,形参的目的就是要让编译器知道函数参数的数据类型. 正 ...

  5. MFC 视图、文档、框架(通讯)

    CMainFrame * pMainWnd=(CMainFrame*)AfxGetApp()->m_pMainWnd;//主框架 CChildFrame * pChild = (CChildFr ...

  6. 开源的读取Excel文件组件-ExcelDataReader

    ExcelDataReader可以读取 Microsoft Excel 文件 ('97-2007),支持Windows  .Net Framework 2 +. Windows Mobile with ...

  7. TChromeTabs 使用日记

    1.如何让 Tab 在拖放时,拖放图形中带有 TabControl 的内容. 增加 ChromeTabs 的 NeedDragImageControl 事件,并在代码中设置 DragControl 为 ...

  8. cdoj 1255 斓少摘苹果 贪心

    斓少摘苹果 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/problem/show/1255 Descr ...

  9. ListView删除选中的多项目

    //ListView删除选中的多项目function DeleteMultSelItems(ListView:TListView):Boolean;var  I: Integer;begin  Res ...

  10. 手机NFC通信的安全车钥匙

    SmartKeys for Cyber-Cars:Secure Smartphone-based NFC-enabled Car Immobicizer 手机NFC通信的安全车钥匙 1概述 如今,智能 ...