hdu4122 制作月饼完成订单的最小花费
题意:
有一个加工厂加工月饼的,这个工厂一共开业m小时,2000年1月1日0点是开业的第一个小时,每个小时加工月饼的价钱也不一样,然后每个月饼的保质期都是t天,因为要放在冰箱里保存,所以在保质期期间每天每个月饼的花费是s,他接到了n个订单,问你完成这n个订单的最小花费是多少?
思路:
想到这样一个性质,在一个序列里面某一个位置的值是由他前面的某一个范围中的一个得到的,而且我们要当前这个位置最小(或者最大),这样的问题可以用单调队列解决,这个题目我们可以弄一个递增的单调队列,小的那头要保证不过期,大的那头要保证递增,这样就ok了,还有对于这个题目,我的方法是吧所有的订单日期全都处理成小时(就是于题目中的m对应)去做,这样能清晰点,还有就是有两个小提示,订单当天做也来得及,还有一个就是两个订单的日期可能相同,别的没什么了,具体细节看下面代码。
#include<map>
#include<string>
#include<stdio.h>
#include<string.h>
#define N 2500 + 50
using namespace std;
map<__int64 ,__int64>mark;
map<string ,int>mk;
__int64 ry[13] = {0 ,31 ,29 ,31 ,30 ,31 ,30 ,31 ,31 ,30 ,31 ,30 ,31};
__int64 py[13] = {0 ,31 ,28 ,31 ,30 ,31 ,30 ,31 ,31 ,30 ,31 ,30 ,31};
__int64 C[110000] ,node[N];
__int64 hash[110000];
int Q[110000];
__int64 tou ,wei;
void DB()
{
mk["Jan"] = 1; mk["Feb"] = 2; mk["Mar"] = 3;
mk["Apr"] = 4; mk["May"] = 5; mk["Jun"] = 6;
mk["Jul"] = 7; mk["Aug"] = 8; mk["Sep"] = 9;
mk["Oct"] = 10; mk["Nov"] = 11; mk["Dec"] = 12;
}
bool jude(__int64 now)
{
return now % 400 == 0 || now % 4 == 0 && now % 100 != 0;
}
void insert(int t ,__int64 tt,__int64 cost)
{
for(int i = wei ;i > tou ;i --)
{
if(C[t] <= (__int64)(t - Q[wei]) * cost + C[Q[wei]])
wei --;
else break;
}
Q[++wei] = t;
for(int i = tou + 1;i <= wei ;i ++)
if(t - Q[i] > tt) tou ++;
}
int main ()
{
int n ,m ,a ,i;
__int64 y ,r ,h ,t ,cost;
char mouse[10];
DB();
while(~scanf("%d %d" ,&n ,&m) && n + m)
{
mark.clear();
for(i = 1 ;i <= n ;i ++)
{
scanf("%s %I64d %I64d %I64d %I64d" ,mouse ,&r ,&y ,&h ,&node[i]);
__int64 now = mk[mouse] * 10000 + y * 1000000 + r * 100 + h * 1;
if(mark[now]) node[mark[now]] += node[i];
else mark[now] = i;
}
memset(hash ,0 ,sizeof(hash));
__int64 nn = 2000,yy = 1 ,rr = 1,ss = 0;
if(mark[nn*1000000+yy*10000+rr*100+ss*1])
{
hash[1] = mark[nn*1000000+yy*10000+rr*100+ss*1];
}
for(i = 2 ;i <= m ;i ++)
{
ss ++;
if(ss == 24) {ss = 0 ,rr ++;}
if(jude(nn) && rr == ry[yy] + 1 || !jude(nn) && rr == py[yy] + 1)
{yy ++ ,rr = 1;}
if(yy == 13) {yy = 1 ;nn ++;}
if(mark[nn*1000000+yy*10000+rr*100+ss*1])
hash[i] = mark[nn*1000000+yy*10000+rr*100+ss*1];
}
scanf("%I64d %I64d" ,&t ,&cost);
for(i = 1 ;i <= m ;i ++)
scanf("%I64d" ,&C[i]);
tou = wei = 0;
__int64 Ans = 0;
for(i = 1 ;i <= m ;i ++)
{
insert(i ,t ,cost);
if(hash[i])
{
int T = Q[tou + 1];
Ans += C[T] * node[hash[i]] + node[hash[i]] * (__int64)(i - T) * cost;
}
}
printf("%I64d\n" ,Ans);
}
return 0;
}
hdu4122 制作月饼完成订单的最小花费的更多相关文章
- Poj 2516 Minimum Cost (最小花费最大流)
题目链接: Poj 2516 Minimum Cost 题目描述: 有n个商店,m个仓储,每个商店和仓库都有k种货物.嘛!现在n个商店要开始向m个仓库发出订单了,订单信息为当前商店对每种货物的需求 ...
- 把一个序列转换成严格递增序列的最小花费 CF E - Sonya and Problem Wihtout a Legend
//把一个序列转换成严格递增序列的最小花费 CF E - Sonya and Problem Wihtout a Legend //dp[i][j]:把第i个数转成第j小的数,最小花费 //此题与po ...
- 把一个序列转换成非严格递增序列的最小花费 POJ 3666
//把一个序列转换成非严格递增序列的最小花费 POJ 3666 //dp[i][j]:把第i个数转成第j小的数,最小花费 #include <iostream> #include < ...
- 第四届CCF软件能力认证(CSP2015) 第五题(最小花费)题解
[问题描述] C国共有$n$个城市.有$n-1$条双向道路,每条道路连接两个城市,任意两个城市之间能互相到达.小R来到C国旅行,他共规划了$m$条旅行的路线, 第$i$条旅行路线的起点是$s_i$,终 ...
- 九度OJ 1086 最小花费--动态规划
题目地址:http://ac.jobdu.com/problem.php?pid=1086 题目描述: 在某条线路上有N个火车站,有三种距离的路程,L1,L2,L3,对应的价格为C1,C2,C3.其对 ...
- hdoj 3072 Intelligence System【求scc&&缩点】【求连通所有scc的最小花费】
Intelligence System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- ccf 201503-5 最小花费 这题交上去只有10分嗨!求大佬的题解啊
问题描述 C国共有n个城市.有n-1条双向道路,每条道路连接两个城市,任意两个城市之间能互相到达.小R来到C国旅行,他共规划了m条旅行的路线,第i条旅行路线的起点是si,终点是ti.在旅行过程中,小R ...
- [LeetCode] Minimum Cost to Merge Stones 混合石子的最小花费
There are N piles of stones arranged in a row. The i-th pile has stones[i] stones. A move consists ...
- 1344:【例4-4】最小花费 dijkstra
1344:[例4-4]最小花费 Dijkstra (1)a [ i ] [ j ] 存转账率(..转后所得率..) (2)dis [ i ] 也就是 a [ 起点 ] [ i ] (3)f [ i ] ...
随机推荐
- ReactElement源码笔记
ReactElement 源码笔记 ReactElement通过 createElement创建,调用该方法需要 传入三个参数: type config children type指代这个ReactE ...
- 剑指 Offer 62. 圆圈中最后剩下的数字 + 约瑟夫环问题
剑指 Offer 62. 圆圈中最后剩下的数字 Offer_62 题目描述 方法一:使用链表模拟 这种方法是暴力方法,时间复杂度为O(nm),在本题中数据量过大会超时. 方法二:递归方法 packag ...
- WS1008网络损伤测试仪
WS1008网络损伤测试仪具备高性能的网络损伤仿真功能.冗余链路测试功能和线速流量生成功能,提供了综合性的网络系统测试方案,可充分测试.验证网络系统的抗损伤能力.链路切换能力及数据转发能力.为高可靠性 ...
- WPF 基础 - Window 启动动画
<Window ... WindowStyle="None" AllowsTransparency="True" RenderTransformOrigi ...
- Python中的描述器
21.描述器:Descriptors 1)描述器的表现 用到三个魔术方法.__get__() __set__() __delete__() 方法签名如下: object.__get__(self ...
- springboot集成swagger实战(基础版)
1. 前言说明 本文主要介绍springboot整合swagger的全过程,从开始的swagger到Knife4j的进阶之路:Knife4j是swagger-bootstarp-ui的升级版,包括一些 ...
- Edge 浏览器开发工具新增了 3D 视图,你尝试了吗?
在使用开发者工具的时候,无意间发现了一个3D面板,如下: 仔细想想,这应该是之前 Firefox 的特性啊,不过后来去掉了,说是太难维护,没想到 Edge 也添加了这个特性. 使用该特性,你可以完成如 ...
- SqlServer存储过程的创建与使用
什么是存储过程? T-SQL中的存储过程,非常类似于net语言中的方法,它可以重复调用.当存储过程执行一次后,可以将语句缓存中,这样下次执行的时候直接使用缓存中的语句. 这样就可以提高存储过程的性能. ...
- JAVA题目:小芳的妈妈每天给她2.5元,她都会存起来,但是,每当这一天是存钱的第五题或者5的倍数的话,她都会去用掉6块钱。 问:至少经过多少天可以存到100块?
1 /*题目:小芳的妈妈每天给她2.5元,她都会存起来, 2 但是,每当这一天是存钱的第五题或者5的倍数的话, 3 她都会去用掉6块钱. 4 问:至少经过多少天可以存到100块? 5 */ 6 /*分 ...
- 尝试做一个.NET简单、高效、避免OOM的Excel工具
Github : https://github.com/shps951023/MiniExcel 简介 我尝试做一个.NET简单.高效.避免OOM的Excel工具 目前主流框架大多将资料全载入到记忆体 ...