HDU 4122 Alice's mooncake shop --RMQ
题意: 一个月饼店做月饼,总营业时间m小时,只能在整点做月饼,可以做无限个,不过在不同的时间做月饼的话每个月饼的花费是不一样的,假设即为cost[i],再给n个订单,即为在某个时间要多少个月饼,时间从2000年1月1日0时开始计算,必须在每个订单的时间之前完成这么多月饼,月饼还有保质期T小时以及保存费用S每小时,现在问满足这n个点的最小成本是多少。
解法:
因为月饼有保质期T,所以第i个月饼只能在[Ti-T+1,Ti]时间内做好。
如果时间j有订单,假设在时间i做月饼是最好的,那么这个订单每个月饼的
花费为 cost[i] + (j-i)*S = cost[i]-i*S + j*S, 由于j不变,所以求cost[i]-i*S的
最小值即可,即求[Ti-T+1,Ti]内的cost[i]-i*S最小值,求区间最小值我们用RMQ可以快速求出
这里RMQ用了一个Log函数优化,使得到k的时间复杂度为O(1)
这里的月份处理采用了kuangbin大神的模板,简洁又好用。
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <algorithm>
#define lll __int64
using namespace std;
#define N 100017 lll d[N][],cost[N];
int LOG[N],n; int getmonth(char s[])
{
if(strcmp(s,"Jan") == ) return ;
if(strcmp(s,"Feb") == ) return ;
if(strcmp(s,"Mar") == ) return ;
if(strcmp(s,"Apr") == ) return ;
if(strcmp(s,"May") == ) return ;
if(strcmp(s,"Jun") == ) return ;
if(strcmp(s,"Jul") == ) return ;
if(strcmp(s,"Aug") == ) return ;
if(strcmp(s,"Sep") == ) return ;
if(strcmp(s,"Oct") == ) return ;
if(strcmp(s,"Nov") == ) return ;
if(strcmp(s,"Dec") == ) return ;
}
int days[] = {,,,,,,,,,,,,};
bool isleap(int y)
{
if(y % == || (y % != && y% == ))return true;
else return false;
}
struct Node
{
char mon[];
int d,y,h,R;
lll tim;
void input()
{
scanf("%s%d%d%d%d",mon,&d,&y,&h,&R);
tim = ;
for(int i = ;i < y;i++)
{
if(isleap(i)) tim += *;
else tim += *;
}
for(int i = ;i < getmonth(mon);i++)
tim += days[i]*;
if(isleap(y) && getmonth(mon) > ) tim += ;
tim += (d-)*;
tim += h+;
}
}order[]; void RMQ_init(int m)
{
int i,j;
for(i=;i<=m;i++)
d[i][] = cost[i];
for(j=;(<<j)<=m;j++)
{
for(i=;i+(<<j)-<=m;i++)
d[i][j] = min(d[i][j-],d[i+(<<(j-))][j-]);
}
}
void getLog(int n)
{
for(int i=;i<=n;i++)
LOG[i] = (int)(log((double)i)/log(2.0));
}
lll RMQ(int l,int r)
{
int k = LOG[r-l+];
return min(d[l][k],d[r-(<<k)+][k]);
} int main()
{
int n,m,T,S,i,j;
while(scanf("%d%d",&n,&m)!=EOF && n+m)
{
getLog(m);
for(i=;i<=n;i++)
order[i].input();
scanf("%d%d",&T,&S);
for(i=;i<=m;i++)
{
scanf("%I64d",&cost[i]);
cost[i] -= i*S;
}
RMQ_init(m);
lll ans = ;
for(i=;i<=n;i++)
{
if(order[i].tim < || order[i].tim > m) continue;
int L = max(1LL,order[i].tim - T + );
int R = order[i].tim;
lll MN = RMQ(L,R);
ans += (MN+order[i].tim*S)*order[i].R;
}
cout<<ans<<endl;
}
return ;
}
HDU 4122 Alice's mooncake shop --RMQ的更多相关文章
- hdu 4122 Alice's mooncake shop(单调队列)
题目链接:hdu 4122 Alice's mooncake shop 题意: 有n个订单和可以在m小时内制作月饼 接下来是n个订单的信息:需要在mon月,d日,year年,h小时交付订单r个月饼 接 ...
- HDU 4122 Alice's mooncake shop (RMQ)
Alice's mooncake shop Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
- HDU 4122 Alice's mooncake shop 单调队列优化dp
Alice's mooncake shop Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem ...
- HDU 4122 Alice's mooncake shop (单调队列/线段树)
传送门:http://acm.hdu.edu.cn/showproblem.php?pid=4122 题意:好难读懂,读懂了也好难描述,亲们就自己凑合看看题意把 题解:开始计算每个日期到2000/1/ ...
- HDU 4122 Alice's mooncake shop
单调队列,裸的!!坑死了,说好的“All the orders are sorted by the time in increasing order. 呢,我就当成严格上升的序列了,于是就各种错.测试 ...
- 【HDOJ】4122 Alice's mooncake shop
RMQ的基础题目,简单题. /* 4122 */ #include <iostream> #include <sstream> #include <string> ...
- hdu 4122 Alice's mooncake shop (线段树)
题目大意: 一个月饼店每一个小时做出月饼的花费不一样. 储存起来要钱.最多存多久.问你把全部订单做完的最少花费. 思路分析: ans = segma( num[]*(cost[] + (i-j)*s) ...
- Alice's mooncake shop HDU - 4122 单调队列
题意: 有n个订单和可以在m小时内制作月饼,制作月饼不考虑时间(即,你可以在一个时刻在所有需要的月饼都做完) 接下来是n个订单的信息:需要在mon月,d日,year年,h小时交付订单r个月饼 接下来一 ...
- HDU 4122
Alice's mooncake shop Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
随机推荐
- mysql bin-log和innodb_log的关系
首先,二进制日志会记录所有与MySQL数据库有关的日志记录,包括InnoDB.MyISAM.Heap(memory除外)等其他存储引擎的日志.而InnoDB存储引擎的重做日志记录有关该引擎本身的事务日 ...
- Javascript面向对象编程(二)--- 构造函数的继承
这个系列的第一部分,主要介绍了如何"封装"数据和方法,以及如何从原型对象生成实例 今天要介绍的是,对象之间的"继承"的五种方法. 比如,现在有一个"动 ...
- Git的安装和使用记录
Git是目前世界上最先进的分布式版本控制系统(没有之一),只用过集中式版本控制工具的我,今天也要开始学习啦.廖雪峰的git教程我觉得很详细了,这里记录一下步骤以及我终于学会用Markdown了,真的是 ...
- 使用SWFUpload无刷新上传图片
使用SWFUpload组件无刷新上传图片 在做项目时,需要用到一个图片的无刷新上传,之前听说过SWFUpload,于是想要通过SWFUpload来进行图片的无刷新上传,由于我的项目属于是ASP.NET ...
- Smartforms常见问题
分类: 1.使用SFSY-FORMPAGES显示总页数的时候,如果页数大于9,将会在前10页显示成星号* 解决: 有时候这样做完之后,星号*是没有了,但是字体会有颠倒或者重叠的现象. 如果出了这个问题 ...
- 详解Paint的各种set方法
一.前言 我们用set方法来设置画笔的样式,类似于我们挑选画笔画画的过程.由于上面有些方法不支持硬件加速,所以在高版本系统中可能会没有效果.因此,我们首先来看看官方废弃的方法. 下图来自:https: ...
- - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath不执行的问题
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPa ...
- 我体验过的可以用的XCode插件
XCode版本:7.0.1 其实插件的使用,如果能得到直接的xclugin后缀文件,是可以直接放置在隐藏文件夹中: /Users/HeYang/Library/Application Support/ ...
- python 读写、创建 文件
python中对文件.文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块. 得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd() 返回指定目录下的所有文件和目 ...
- Effective Java 72 Don't depend on the thread scheduler
Principle Any program that relies on the thread scheduler for correctness or performance is likely t ...