【问题描述】

一个餐厅在相继的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 。

【输出】

一行,最小的费用

【样例】

napkin.in


3 2 4 
10 1 6 2 3

napkin.out

64

【数据规模】

n<=200,Ri<=50 (洛谷 n<=2000,Ri<=10000000)

  1. /*
  2. 放到洛谷上会TLE,数据太大了,cogs可过,大数据可用网络流,蒟蒻不懂。
  3. 可以看出是贪心,但是贪心策略不容易想到。
  4. 如果考虑餐巾的去路,那我们要考虑有多少快洗和慢洗,这时就要枚举,不仅麻烦时间复杂度也高,所以应考虑餐巾的来源。
  5. 首先,如果要买一定数量的餐巾,应买的越早越好,因为这样至今循环利用可以省钱,但我们不知道究竟用多少餐巾,所以要枚举餐巾的数量,另外买的餐巾不够数了,就要考虑慢洗,再考虑快洗。
  6. (前提是餐巾一定要够用)
  7. */
  8. #include<cstdio>
  9. #include<iostream>
  10. #include<cstring>
  11. #define M 2010
  12. using namespace std;
  13. int xu[M],q[M],n,p,t1,v1,t2,v2;
  14. int read()
  15. {
  16. char c=getchar();int num=,flag=;
  17. while(c<''||c>''){if(c=='-')flag=-;c=getchar();}
  18. while(c>=''&&c<=''){num=num*+c-'';c=getchar();}
  19. return num*flag;
  20. }
  21. int init(int sum)
  22. {
  23. int ans=;
  24. memset(q,,sizeof(q));
  25. for(int i=;i<=n;i++)
  26. {
  27. int x=xu[i];
  28. if(sum>=x)
  29. {
  30. ans+=x*p;
  31. q[i]+=x;
  32. sum-=x;
  33. x=;
  34. }
  35. else if(sum>)
  36. {
  37. ans+=sum*p;
  38. q[i]+=sum;
  39. x-=sum;
  40. sum=;
  41. }
  42. ////////////慢洗
  43. for(int j=;j<=i-t2;j++)
  44. if(q[j]>)
  45. {
  46. if(q[j]>=x)
  47. {
  48. ans+=x*v2;
  49. q[j]-=x;
  50. q[i]+=x;
  51. x=;
  52. break;
  53. }
  54. else
  55. {
  56. ans+=q[j]*v2;
  57. q[i]+=q[j];
  58. x-=q[j];
  59. q[j]=;
  60. }
  61. }
  62. ///////////快洗
  63. if(!x)continue;
  64. for(int j=i-t1;j>=;j--)//快洗的时候优先选后面的,被坑了好长时间!!!
  65. if(q[j]>)
  66. {
  67. if(q[j]>=x)
  68. {
  69. ans+=x*v1;
  70. q[j]-=x;
  71. q[i]+=x;
  72. x=;
  73. break;
  74. }
  75. else
  76. {
  77. ans+=q[j]*v1;
  78. q[i]+=q[j];
  79. x-=q[j];
  80. q[j]=;
  81. }
  82. }
  83. if(x>)return ;
  84. }
  85. return ans;
  86. }
  87. int main()
  88. {
  89. freopen("napkin.in","r",stdin);
  90. freopen("napkin.out","w",stdout);
  91. int maxn=,sum=;
  92. n=read();
  93. for(int i=;i<=n;i++)
  94. xu[i]=read(),maxn=max(maxn,xu[i]),sum+=xu[i];
  95. p=read();t1=read();v1=read();t2=read();v2=read();
  96. int ans=sum*p;
  97. for(int i=sum-;i>=maxn;i--)
  98. {
  99. int p=init(i);
  100. if(p)ans=min(ans,p);
  101. }
  102. printf("%d",ans);
  103. return ;
  104. }

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

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

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

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

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

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

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

  4. cogs 餐巾 461(贪心)

    /*虽然这暴力剪了又剪 改了又改 还是初始的20分...*/ #include<iostream> #include<cstdio> #include<cstring&g ...

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

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

  6. COGS461. [网络流24题] 餐巾

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

  7. LeetCode:461. Hamming Distance

    package BitManipulation; //Question 461. Hamming Distance /* The Hamming distance between two intege ...

  8. 【COGS 254】【POI 2001】交通网络图

    http://www.cogs.top/cogs/problem/problem.php?pid=254 dist[i]表示能最早到达i点的时间.这样就可以用最短路模型来转移了. #include&l ...

  9. 【COGS】894. 追查坏牛奶

    http://cojs.tk/cogs/problem/problem.php?pid=894 题意:n个点m条边的加权网络,求最少边数的按编号字典序最小的最小割.(n<=32, m<=1 ...

随机推荐

  1. 自动判断手机版和pc版

    <html><head><title>欢迎来到手机版</title><script>var ua = navigator.userAgent ...

  2. 前台js获得json数据

    $.ajax({ type:"post", url:"testAction.action", data:{ classId:classId }, success ...

  3. [Luogu1345][USACO5.4]Telecowmunication 最大流

    题目链接:https://www.luogu.org/problem/show?pid=1345 求最小割点集的大小,直接拆点转化成最小割边.把一个点拆成出点入点,入点向出点连一条容量为1的边,其他的 ...

  4. CCF|跳一跳

    import java.util.Scanner; public class Main { public static void main (String[] args) { Scanner scan ...

  5. json两层解析

    public class Demo { public static void main(String[] args) { try { // 创建连接 服务器的连接地址 URL url = new UR ...

  6. Python学习 Day 3 字符串 编码 list tuple 循环 dict set

    字符串和编码 字符 ASCII Unicode UTF-8 A 1000001 00000000 01000001 1000001 中 x 01001110 00101101 11100100 101 ...

  7. MySQL学习随笔--通过实例理解merge ,temptable算法的差异

    实例1 使用视图的两种算法merge和temptable分别统计 表tb_phone中market_price大于4000的手机,然后查询视图查找出小于6000的手机 简单总结最终获取的结果:查询出m ...

  8. win8怎么打开或关闭快速启动(进入BIOS前的设置)

    win8系统之后,系统添加了快速启动功能,这让Windows的启动速度快了不少.但是,任何事物有利有弊,相信不少人在进入BIOS或者重装系统时遇到了麻烦.接下来我们看看在win8及以上版本怎么打开或关 ...

  9. iOS微信页面 长按图片出现【存储图像】和【拷贝】不出现【发送朋友】【保存图片】

    最近遇到一大坑.微信加载的页面中出现图片,长按图片时不出现默认的菜单[发送朋友]等而是[存储图像]和拷贝. 原因:正常在页面中长按图片是没有问题的,但是如果你的页面嵌入了ifram然后又长按在ifra ...

  10. Ajax请求WebService跨域问题

    1.背景 用Jquery中Ajax方式在asp.net开发环境中WebService接口的调用 2.出现的问题 原因分析:浏览器同源策略的影响(即JavaScript或Cookie只能访问同域下的内容 ...