标题很长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]餐巾计划问题——题解的更多相关文章

  1. BZOJ1229 USACO2008 Nov toy 玩具 【三分+贪心】*

    BZOJ1229 USACO2008 Nov toy 玩具 Description 玩具 [Chen Hu, 2006] Bessie的生日快到了, 她希望用D (1 <= D <= 10 ...

  2. BZOJ 1229: [USACO2008 Nov]toy 玩具

    BZOJ 1229: [USACO2008 Nov]toy 玩具 标签(空格分隔): OI-BZOJ OI-三分 OI-双端队列 OI-贪心 Time Limit: 10 Sec Memory Lim ...

  3. BZOJ_1229_[USACO2008 Nov]toy 玩具_三分+贪心

    BZOJ_1229_[USACO2008 Nov]toy 玩具_三分+贪心 Description 玩具 [Chen Hu, 2006] Bessie的生日快到了, 她希望用D (1 <= D ...

  4. Bzoj 1229: [USACO2008 Nov]toy 玩具 题解 三分+贪心

    1229: [USACO2008 Nov]toy 玩具 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 338  Solved: 136[Submit] ...

  5. 【BZOJ】1229 [USACO2008 Nov]toy 玩具

    [算法]三分+贪心 [题解] 数据范围小的版本:餐巾计划 这题不是使用最小费用流的下凸函数,因为这题是要满足最大流,那么这题到底在三分什么? 三分的这个函数,其实是总费用随卖出玩具量变化而变化的函数, ...

  6. BZOJ 1229 [USACO2008 Nov]toy 玩具(三分+贪心)

    [题木链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1229 [题目大意] 每天对玩具都有一定的需求ni,每天可以花f价值每条购买玩具, 当天 ...

  7. BZOJ 1230: [Usaco2008 Nov]lites 开关灯( 线段树 )

    线段树.. --------------------------------------------------------------------------------- #include< ...

  8. 1230: [Usaco2008 Nov]lites 开关灯

    1230: [Usaco2008 Nov]lites 开关灯 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1162  Solved: 589[Sub ...

  9. [Usaco2008 Nov]mixup2 混乱的奶牛 简单状压DP

    1231: [Usaco2008 Nov]mixup2 混乱的奶牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 685  Solved: 383[S ...

随机推荐

  1. Redis系列四 Redis常见配置

    redis.conf常见配置 参数说明redis.conf 配置项说明如下:1. Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程  daemonize no2. ...

  2. 2019年猪年海报PSD模板-第八部分

    11套精美猪年海报,免费猪年海报,下载地址:百度网盘,https://pan.baidu.com/s/1Y3wc_r7O-Dp0mLCihJ9mtQ            

  3. C++ 基础面试题-1

    请说出下面代码在32位系统下的输出内容 /* ** 2018/03/21 21:43:00 ** Brief: ** Author:ZhangJianWei ** Email:Dream_Dog@16 ...

  4. OSG-更新和回调

    本文转至http://www.cnblogs.com/shapherd/archive/2010/08/10/osg.html 作者写的比较好,再次收藏,希望更多的人可以看到这个文章 互联网是是一个相 ...

  5. Python简要标准库(1)

    sys sys这个模块让你能够访问与Python解释器联系紧密的变量和函数 其中的一些在下表 F argv 命令行参数,包括脚本名称 exit([arg]) 退出当前的程序,可选参数为给定的返回值或者 ...

  6. 卡片游戏 (Throwing card away I,UVa10935)

    题目描述: 解题思路: 直接模拟 #include <iostream> using namespace std; ] ; int main(int argc, char *argv[]) ...

  7. lr 常用操作

    lr脚本编写语法: web_add_cookie();:服务器注入cookies lr_save_string("网址或其他","参数2");:一个保存函数,它 ...

  8. 如何借助windows的VHD引导特性实现VHD多windows系统共存

    近期,由于一些需要,需要运行3个windows系统,具体需要如何此处略去,现将实现方式共享如下. 测试环境: HP 820 G2, 4G内存, 500G SSD硬盘 windows 7 企业版 win ...

  9. 【Linux 运维】 Centos7.x 系统修复模式

    一.linux的运行级别: 运行级别就是来确定系统启动时到底启动那个服务. linux默认有7个运行级别: 0 关机 1 单用户模式,用于系统修复 2 不完全的命令模式,不含NFS服务 3 完全的命令 ...

  10. Skype for Business Server 方案

    方案说明: 高可用性的配置屏蔽了单点故障,使得当一个服务器节点失效时,另外的可用的节点能够进行服务的接管.可伸缩性的配置可以保证当即时沟通平台的使用用户增加时,该平台应该具有良好的可伸缩性,能非常方便 ...