BZOJ1229 USACO2008 Nov toy 玩具


Description

玩具 [Chen Hu, 2006]

Bessie的生日快到了, 她希望用D (1 <= D <= 100,000; 70%的测试数据都满足 1 <= D <= 500)天来庆祝. 奶牛们的注意力不会太集中, 因此Bessie想通过提供玩具的方式来使它们高兴. 她已经计算出了第i天需要的玩具数T_i (1 <= T_i <= 50). Bessie的幼儿园提供了许多服务给它们的奶牛程序员们, 包括一个每天以Tc (1 <= Tc <= 60)美元卖出商品的玩具店. Bessie想尽可能的节省钱, 但是Farmer John担心没有经过消毒的玩具会带来传染病(玩具店卖出的玩具是经过消毒的). 有两种消毒的方式. 第1种方式需要收费C1美元, 需要N1个晚上的时间; 第2种方式需要收费 C2美元, 需要N2个晚上的时间(1 <= N1 <= D; 1 <= N2 <= D; 1 <= C1 <= 60; 1 <= C2 <= 60). Bessie在party结束之后把她的玩具带去消毒. 如果消毒只需要一天, 那么第二天就可以拿到; 如果还需要一天, 那么第三天才可以拿到. 作为一个受过教育的奶牛, Bessie已经了解到节约的意义. 帮助她找到提供玩具的最便宜的方法.

Input

  • 第 1 行: 六个用空格隔开的整数 D, N1, N2, C1, C2, Tc
  • 第 2..D+1 行: 第 i+1 行包含一个整数: T_i

Output

第 1 行: 提供玩具所需要的最小费用.

Sample Input

4 1 2 2 1 3

8

2

1

6

输入解释:

Bessie想开4天的party, 第1天需要8个玩具, 第2天需要2个玩具, 第3天需要1个玩具,

第4天需要6个玩具. 第一种方式需要2,用时1天;第二种方式需要" role="presentation">2,用时1天;第二种方式需要2,用时1天;第二种方式需要1, 用时2天. 买

一个玩具需要$3.

Sample Output

35

输出解释:

第 1 天 买8个玩具, 花去24; 送2个玩具去快洗, 6个慢洗.

第 2 天 取回2个快洗的玩具, 花去4. 送1个玩具去慢洗.

第 3 天 取回6个慢洗的玩具, 花去6.

第 4 天 取回所有的玩具(与现有的加在一起正好6个), 花去1. 这样就用了最少的钱.


我们可以考虑当购买的玩具确定的时候会发生什么

很显然除了一些玩具数太少的情况其他的情况都是可行的

然后我也不知道为什么花费是单峰的

网上好像也没什么大佬给出了证明

可以意会一下,当购买的玩具增加,购买的花费呈一次函数,然后消毒的花费应该是递减的,然后好像可以想当然的认为这是个单峰函数

然后就三分+check

在check的时候可以维护一下当前可以用第一种方案消毒的,可以第二种方案消毒的然后进行贪心,至于不合法的状态直接判过去就好了


#include<bits/stdc++.h>
using namespace std;
#define N 100010
#define INF 0x3f3f3f3f
#define pi pair<int,int>
int n,n1,n2,c1,c2,tc;
int d[N];
deque<pi> t,p,q;
int calc(int x){
t.clear();
p.clear();
q.clear();
int sum=(tc-c2)*x;
p.push_back(make_pair(0,x));
for(int i=1;i<=n;++i){
while(!t.empty()&&i-t.front().first>=n1)q.push_back(t.front()),t.pop_front();
while(!q.empty()&&i-q.front().first>=n2)p.push_back(q.front()),q.pop_front();
int now=d[i];
while(now){
if(!p.empty()){
if(p.back().second>now){
p.back().second-=now;
sum+=now*c2;now=0;
break;
}
now-=p.back().second;
sum+=p.back().second*c2;
p.pop_back();
continue;
}
if(!q.empty()){
if(q.back().second>now){
q.back().second-=now;
sum+=now*c1;now=0;
break;
}
now-=q.back().second;
sum+=q.back().second*c1;
q.pop_back();
continue;
}
return INF;
}
t.push_back(make_pair(i,d[i]));
}
return sum;
}
int main(){
freopen("1229.in","r",stdin);
scanf("%d%d%d%d%d%d",&n,&n1,&n2,&c1,&c2,&tc);
if(n1>n2)swap(c1,c2),swap(n1,n2);
int sum=0;
for(int i=1;i<=n;i++)scanf("%d",&d[i]),sum+=d[i];
int l=1,r=sum;
while(l+10<r){
int tmp=(r-l)/3;
int ll=l+tmp,rr=r-tmp;
if(calc(ll)<calc(rr))r=rr;
else l=ll;
}
int ans=INF;
for(int i=l;i<=r;i++)ans=min(ans,calc(i));
printf("%d",ans);
return 0;
}

BZOJ1229 USACO2008 Nov toy 玩具 【三分+贪心】*的更多相关文章

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

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

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

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

  3. BZOJ1229 & 洛谷2917:[USACO2008 NOV]toy 玩具 & 洛谷4480:[BJWC2018]餐巾计划问题——题解

    标题很长emmm…… [USACO2008 NOV]toy 玩具 https://www.luogu.org/problemnew/show/P2917 https://www.lydsy.com/J ...

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

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

  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. 1620: [Usaco2008 Nov]Time Management 时间管理

    1620: [Usaco2008 Nov]Time Management 时间管理 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 506  Solved: ...

随机推荐

  1. Python基础笔记系列十三:socket网络编程

    本系列教程供个人学习笔记使用,如果您要浏览可能需要其它编程语言基础(如C语言),why?因为我写得烂啊,只有我自己看得懂!!使用python编写一个简易的服务端程序和客户端程序,启动服务端和客户端(监 ...

  2. 动态延迟加载网页元素jQuery插件scrollLoading

    如果一个网页很长,那么该页面的加载时间也会相应的较长.而这里给大家介绍的这个jQuery插件scrollLoading的作用则是,对页面元素进行动态加载,通俗的说就是滚到哪就加载到哪,屏幕以下看不见的 ...

  3. zookeeper常见错误

    1.在注册中心找不到对应的服务 这种错误是服务层代码没有成功注册到注册中心导致,请检查一下你的服务层代码是否添加了@service注解,并且该注解的包一定是com.alibaba.dubbo.conf ...

  4. cookie、session、sessionStorage、localStorage

    Cookie cookie是存储在浏览器端,并且随浏览器的请求一起发送到服务器端的,它有一定的过期时间,到了过期时间自动会消失. 首次设置cookie时是由服务器端发送到浏览器端 ,之后每次浏览器发送 ...

  5. NC 工具的使用教程

    NC工具的使用说明...nc使用说明 参数介绍: nc.exe -h即可看到各参数的使用方法. 基本格式:nc [-options] hostname port[s] [ports] ... nc - ...

  6. Linux命令 ls -l 输出内容含义详解

    Linux命令 ls -l s输出内容含义详解   1. ls  只显示文件名或者文件目录 2. ls -l(这个参数是字母L的小写,不是数字1) 用来查看详细的文件资料 在某个目录下键入ls -l可 ...

  7. vue elementui二级联动下拉选项demo

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. RMAN中format的参数

    (转自:http://blog.chinaunix.net/uid-23079711-id-2554290.html) format 的替换变量,注意大小写! 1.     %d --数据库的db_n ...

  9. (转载) jQuery页面加载初始化的3种方法

    jQuery 页面加载初始化的方法有3种 ,页面在加载的时候都会执行脚本,应该没什么区别,主要看习惯吧,本人觉得第二种方法最好,比较简洁. 第一种: $(document).ready(functio ...

  10. Prism 4 文档 ---第9章 松耦合组件之间通信

    当构建一个大而负责的应用程序时,通用的做法时将功能拆分到离散的模块程序集中.将模块之间的静态引用最小化.这使得模块可以被独立的开发,测试,部署和升级,以及它迫使松散耦合的沟通. 当在模块之间通信时,你 ...