BZOJ1229 & 洛谷2917:[USACO2008 NOV]toy 玩具 & 洛谷4480:[BJWC2018]餐巾计划问题——题解
标题很长emmm……
[USACO2008 NOV]toy 玩具
https://www.luogu.org/problemnew/show/P2917
https://www.lydsy.com/JudgeOnline/problem.php?id=1229
[BJWC2018]餐巾计划问题
https://www.luogu.org/problemnew/show/P4480
其中[BJWC2018]餐巾计划问题的数据范围更大,且数据强度可能更强,因此下文围绕该问题展开。
一个餐厅在相继的n天里,每天需用的餐巾数不尽相同。假设第i天(i=1,2,...,n)(i=1,2,...,n)需要ri块餐巾。餐厅可以在任意时刻购买新的餐巾,每块餐巾的费用为p。
使用过的旧餐巾,则需要经过清洗才能重新使用。把一块旧餐巾送到清洗店A,需要等待m1天后才能拿到新餐巾,其费用为c1;把一块旧餐巾送到清洗店B,需要等待m2天后才能拿到新餐巾,其费用为c2。
例如,将一块第k天使用过的餐巾送到清洗店A清洗,则可以在第k+m1天使用。
请为餐厅合理地安排好n天中餐巾使用计划,使总的花费最小。
对于50%的数据,我们有一个很经典的网络流做法洛谷1251:[网络流24题]餐巾计划问题。
但是数据规模扩大后就显然不能用网络流求解了。
分两种情况:
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=;
- const int INF=;
- inline int read(){
- int X=,w=;char ch=;
- while(ch<''||ch>''){if(ch=='-')w=-;ch=getchar();}
- while(ch>=''&&ch<='')X=(X<<)+(X<<)+ch-'',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=;
- int ans=(tc-c2)*k;
- add(-,k);
- for(int i=;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>){
- if(so!=eo){
- if(num[eo-]>j){
- ans+=c2*j;
- num[eo-]-=j;
- break;
- }
- else{
- ans+=c2*num[eo-];
- j-=num[eo-];
- eo--;
- }
- }
- else if(sm!=em){
- if(num[em-]>j){
- ans+=c1*j;
- num[em-]-=j;
- break;
- }
- else{
- ans+=c1*num[em-];
- j-=num[em-];
- em--;
- }
- }
- else return INF;
- }
- add(i,t[i]);
- }
- return ans;
- }
- int sfen(int l,int r){
- while(){
- if(r-l<=){
- int m=INF;
- for(int i=l;i<r;i++)m=min(m,f(i));
- return m;
- }
- int mid1=l+(r-l)/,mid2=l+*(r-l)/;
- 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=,c2=;
- int tsum=;
- for(int i=;i<=d;i++){
- t[i]=read();tsum+=t[i];
- }
- printf("%d\n",sfen(,tsum+));
- return ;
- }
+++++++++++++++++++++++++++++++++++++++++++
+本文作者:luyouqi233。 +
+欢迎访问我的博客:http://www.cnblogs.com/luyouqi233/+
+++++++++++++++++++++++++++++++++++++++++++
BZOJ1229 & 洛谷2917:[USACO2008 NOV]toy 玩具 & 洛谷4480:[BJWC2018]餐巾计划问题——题解的更多相关文章
- BZOJ1229 USACO2008 Nov toy 玩具 【三分+贪心】*
BZOJ1229 USACO2008 Nov toy 玩具 Description 玩具 [Chen Hu, 2006] Bessie的生日快到了, 她希望用D (1 <= D <= 10 ...
- BZOJ 1229: [USACO2008 Nov]toy 玩具
BZOJ 1229: [USACO2008 Nov]toy 玩具 标签(空格分隔): OI-BZOJ OI-三分 OI-双端队列 OI-贪心 Time Limit: 10 Sec Memory Lim ...
- BZOJ_1229_[USACO2008 Nov]toy 玩具_三分+贪心
BZOJ_1229_[USACO2008 Nov]toy 玩具_三分+贪心 Description 玩具 [Chen Hu, 2006] Bessie的生日快到了, 她希望用D (1 <= D ...
- Bzoj 1229: [USACO2008 Nov]toy 玩具 题解 三分+贪心
1229: [USACO2008 Nov]toy 玩具 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 338 Solved: 136[Submit] ...
- 【BZOJ】1229 [USACO2008 Nov]toy 玩具
[算法]三分+贪心 [题解] 数据范围小的版本:餐巾计划 这题不是使用最小费用流的下凸函数,因为这题是要满足最大流,那么这题到底在三分什么? 三分的这个函数,其实是总费用随卖出玩具量变化而变化的函数, ...
- BZOJ 1229 [USACO2008 Nov]toy 玩具(三分+贪心)
[题木链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1229 [题目大意] 每天对玩具都有一定的需求ni,每天可以花f价值每条购买玩具, 当天 ...
- BZOJ 1230: [Usaco2008 Nov]lites 开关灯( 线段树 )
线段树.. --------------------------------------------------------------------------------- #include< ...
- 1230: [Usaco2008 Nov]lites 开关灯
1230: [Usaco2008 Nov]lites 开关灯 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1162 Solved: 589[Sub ...
- [Usaco2008 Nov]mixup2 混乱的奶牛 简单状压DP
1231: [Usaco2008 Nov]mixup2 混乱的奶牛 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 685 Solved: 383[S ...
随机推荐
- Codeforces Round #495 (Div. 2) Sonya and Matrix
正常没有正方形的限制下,值为i的点个数4i 那么从0开始遍历,第一个不为4i的值就是min(x, y) 由于对称性我们姑且令x为这个值 我们先列举n*m=t的各种情况 对于一对n, m.我们已经知道n ...
- C++0x,std::move和std::forward解析
1.std::move 1.1std::move是如何定义的 template<typename _Tp> constexpr typename std::remove_reference ...
- 【MySQL解惑笔记】忘记MySQL数据库密码
破解MySQL密码 一.MySQL5.7.5之前 只要有系统root密码就可以破解: [root@host- ~]# vim /etc/my.cnf //在配置文件中加入如下内容 [mysqld] s ...
- mouseover 和 mouseout 事件是可以冒泡的 取消
mouseover 和 mouseout 事件是可以冒泡的,子元素上触发的事件会冒泡到父元素上.可以改用 mouseleave 和 mouseenter 事件,这两个事件不冒泡.
- nodejs笔记--Events篇(二)
常用事件 /* 调用events模块,获取events.EventEmitter对象 */ var EventEmitter = require('events').EventEmitter; var ...
- 解读:未来30年新兴科技趋势报告(AI Frist,IoT Second)
前段时间美国公布的一份长达35页的<未来30年新兴科技趋势报告>.该报告是在美国过去五年内由政府机构.咨询机构.智囊团.科研机构等发表的32份科技趋势相关研究调查报告的基础上提炼形成的. ...
- 默认初始化&拷贝初始化&直接初始化&值初始化&列表初始化
一.各种初始化的形式 /* 定义变量形式一:不指定初始值 */ int a; // 默认初始化 /* 定义变量形式二:指定初始值 */ int b = 1; // 拷贝初始化 int b(1); // ...
- 《剑指offer》---字符串的全排列
本文算法使用python3实现 1.问题一 1.1 题目描述: 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc ...
- iOS-Masonry用法
__weak typeof(self) weakSelf = self; UIView * tempView = [[UIView alloc]init]; NSInteger count = ;// ...
- Personal summary 个人总结
一.请回望开学时的第一次作业,你对于软件工程课程的想象 对比开篇博客你对课程目标和期待,"希望通过实践锻炼,增强计算机专业的能力和就业竞争力",对比目前的所学所练所得,在哪些方面达 ...