这道题和网络流 \(24\) 题中的餐巾计划的确不一样, \([\) \(BJWC\) \(2018\) \(]\) 餐巾计划问题的数据范围更大。

一个餐厅在相继的 \(n\) 天里,每天需用的餐巾数不尽相同。假设第 \(i\) 天 \((\) \(i\) \(=\) \(1\) \(,\) \(2\) \(,\) \(...\) \(,\) \(n\) \()\)需要 \(ri\) 块餐巾。餐厅可以在任意时刻购买新的餐巾,每块餐巾的费用为 \(p\) 。

使用过的旧餐巾,则需要经过清洗才能重新使用。把一块旧餐巾送到清洗店 \(A\) ,需要等待 \(m1\) 天后才能拿到新餐巾,其费用为 \(c1\);把一块旧餐巾送到清洗店 \(B\) ,需要等待 \(m2\) 天后才能拿到新餐巾,其费用为 \(c2\) 。

例如,将一块第k天使用过的餐巾送到清洗店 \(A\) 清洗,则可以在第 \(k\) \(+\) \(m1\) 天使用。

对于 \(50\) \(%\) 的数据,我们有一个很经典的网络流做法:餐巾计划问题。

但是数据规模扩大后就显然不能用网络流求解了。

分两种情况:

\(1\) .快洗店更贵:

考虑到先买和后买餐巾所对答案和过程不会造成影响,且当买餐巾 \(c\) 条达到最优解时,显然 \(c\) \(+\) \(k\) 的花费比 \(c\) \(+\) \(k\) \(+\) \(1\) 的花费更少。

并且不难感性证出 \(c\) \(-\) \(k\) 的花费比 \(c\) \(-\) \(k\) \(-\) \(1\) 的花费更少 ( 会在最优情况下多次使用快洗店的餐巾使得钱变多 ) 。

因此我们可以三分求解。

最便宜的显然是先使用新的毛巾,等到没了的时候使用慢洗店的,最差使用快洗店的得出答案,使用队列维护一下即可 \((\) 虽然这么说,也是挺恶心的,我对着别人的代码调了 \(3h\) 才过,可能现在让我解释代码都解释不明白。 \()\)

\(2\) .快洗点更便宜:

那就都快洗,这是显然的。

这是可爱的代码

#include<cmath>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
const int N=200010;
const int INF=2147483647;
inline int read(){int X=0,w=1;char ch=0;while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}while(ch>='0'&&ch<='9')X=(X<<1)+(X<<3)+ch-'0',ch=getchar();return X*w;
}
int t[N],num[N],q[N],cnt,d,n1,n2,c1,c2,tc;
int sn,sm,so,en,em,eo;
inline void add(int x,int p){q[en]=x;num[en++]=p;
}
int f(int k){sn=sm=so=en=em=eo=0;int ans=(tc-c2)*k;add(-2000000,k);for(int i=1;i<=d;i++){int j=t[i];while(sn!=en&&i-q[sn]>=n1){num[em]=num[sn];q[em++]=q[sn++];}while(sm!=em&&i-q[sm]>=n2){num[eo]=num[sm];q[eo++]=q[sm++];}while(j>0){if(so!=eo){if(num[eo-1]>j){ans+=c2*j;num[eo-1]-=j;break;}else{ans+=c2*num[eo-1];j-=num[eo-1];eo--;}}else if(sm!=em){if(num[em-1]>j){ans+=c1*j;num[em-1]-=j;break;}else{ans+=c1*num[em-1];j-=num[em-1];em--;}}else return INF;}add(i,t[i]);}return ans;
}
int sfen(int l,int r){while(233){if(r-l<=2){int m=INF;for(int i=l;i<r;i++)m=min(m,f(i));return m;}int mid1=l+(r-l)/3,mid2=l+2*(r-l)/3;int a=f(mid1);if(a!=INF&&a<=f(mid2))r=mid2;else l=mid1;}
}
int main(){d=read(),n1=read(),n2=read(),c1=read(),c2=read(),tc=read();if(n1>n2){swap(n1,n2);swap(c1,c2);}if(c1<=c2)n2=2000001,c2=101;int tsum=0;for(int i=1;i<=d;i++){t[i]=read();tsum+=t[i];}printf("%d\n",sfen(0,tsum+1));return 0;
}

转载于:https://www.cnblogs.com/errichto/p/11317278.html

洛谷P4480 【[BJWC2018]餐巾计划问题】相关推荐

  1. 【洛谷】P1137旅行计划

    [洛谷]P1137旅行计划 题目描述 小明要去一个国家旅游.这个国家有N个城市,编号为1至N,并且有M条道路连接着,小明准备从其中一个城市出发,并只往东走到城市i停止. 所以他就需要选择最先到达的城市 ...

  2. 洛谷千题复习计划(一)(Codeforces + AtCoder)

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 每天花一个小时简单复习一下我写过的洛谷的题目! 虽然还没有到千题,但是快了(等我复习完这些以后我 lu ...

  3. 我的洛谷冬日绘板计划

    我为什么要画这个? 首先,这是一只金色的企鹅--不是鸭子啦! 金企鹅(JQE)是我的一个学长,从我走上oi这条路开始,他就一直在给予我极大的帮助. 可是oi的美好时光流逝得太快,现在他已经高三了,成为 ...

  4. 外卖(food) 洛谷4040宅男计划 三分套二分贪心

    food评测传送门 [题目描述] 叫外卖是一个技术活,宅男宅女们一直面对着一个很大的矛盾,如何以有限的金钱在宿舍宅得尽量久.     外卖店一共有 N 种食物,每种食物有固定的价钱 Pi 与保质期 S ...

  5. 洛谷 P2762 太空飞行计划问题

    题目背景 题目描述 W 教授正在为国家航天中心计划一系列的太空飞行.每次太空飞行可进行一系列商业性实验而获取利润.现已确定了一个可供选择的实验集合E={E1,E2,-,Em},和进行这些实验需要使用的 ...

  6. 洛谷 P2762 太空飞行计划问题(自己理解的口胡版)

    题目描述 W 教授正在为国家航天中心计划一系列的太空飞行.每次太空飞行可进行一系列商业性实验而获取利润.现已确定了一个可供选择的实验集合E={E1,E2,-,Em},和进行这些实验需要使用的全部仪器的 ...

  7. 【洛谷_P1137】旅行计划

    旅行计划 题目描述 小明要去一个国家旅游.这个国家有#NN个城市,编号为11至NN,并且有MM条道路连接着,小明准备从其中一个城市出发,并只往东走到城市i停止. 所以他就需要选择最先到达的城市,并制定 ...

  8. 洛谷 2680 (NOIp2015) 运输计划

    题目:https://www.luogu.org/problemnew/show/P2680 因为是最长的时间最短,所以二分! 离线LCA可以知道路径长度.每次只看超过二分值的路径. 原本的想法是遍历 ...

  9. 洛谷 P3627 [APIO2009]抢掠计划 题解

    Analysis 建图+强连通分量+SPFA求最长路 但要保证最后到达的点中包含酒馆 虽然思路并不难想,但要求的代码能力很高. 1 #include<iostream> 2 #includ ...

最新文章

  1. 独家 | 支持向量机背后的数学 -对于SVM背后的数学和理论解释的快速概览及如何实现...
  2. 成功解决KeyError: “Passing list-likes to .loc or [] with any missing labels is no longer supported. The
  3. 远程桌面中指定在用户登录时启动的程序
  4. git 怎么备份本地分支_Git常用个人备份笔记
  5. spring mvc 实现单文件 || 多文件上传
  6. php_mysql注入load_file()IIS配置文件获取
  7. Windows Embedded CE 6.0开发初体验(三)设置Boot-loader
  8. 什么是机器学习?有哪些应用?终于有人讲明白了
  9. 收集一些jQueryMobile的插件和案例
  10. 百度地图坐标转换的异步回调事件
  11. 第一章 安装和使用SQL Server 2008 R2
  12. 2021Java学习路线总结
  13. 虚拟机中centos7找不到vim命令的解决方法
  14. html 卫星地图显示地名,卫星图看:河南10个名字非常好听的县(区),你认识几个?...
  15. [收藏] 抽奖活动的高可用、高并发优化
  16. 20170321多益在线笔试(二笔)
  17. 华为杭州研究所面试记
  18. 【Cheatsheet】Java的常用代码(以及eclipse技巧)
  19. 机器人竟会写诗,诗人们大呼不敢相信!
  20. 积分分离PID控制算法

热门文章

  1. Html_div圆角
  2. vim中如何按一个键就保存文件
  3. vs2008与IIS 7.0使用在vista上时出现的问题及解决方法(Internet Explorer 无法显示该页面)(VS2008: IE Cannot Display Web Page)...
  4. mysql innodbmaxdirtypagespct_MySQL参数解析innodb_max_dirty_pages_pct
  5. 加载多瓦片地图_手把手教 | 网络时空大数据爬取与分析DAS系统(瓦片地图获取)...
  6. 默的各种写法图片_SEO标题写法?
  7. 学校计算机机房好处,浅谈学校计算机机房维护
  8. java 重写构造函数,覆盖Java中的默认构造函数
  9. java 汇率使用的数据类型_Flink计算支持的数据类型
  10. mysql中关系怎么弄_mysql数据库关系操作