题意:

      有一个加工厂加工月饼的,这个工厂一共开业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 制作月饼完成订单的最小花费的更多相关文章

  1. Poj 2516 Minimum Cost (最小花费最大流)

    题目链接: Poj  2516  Minimum Cost 题目描述: 有n个商店,m个仓储,每个商店和仓库都有k种货物.嘛!现在n个商店要开始向m个仓库发出订单了,订单信息为当前商店对每种货物的需求 ...

  2. 把一个序列转换成严格递增序列的最小花费 CF E - Sonya and Problem Wihtout a Legend

    //把一个序列转换成严格递增序列的最小花费 CF E - Sonya and Problem Wihtout a Legend //dp[i][j]:把第i个数转成第j小的数,最小花费 //此题与po ...

  3. 把一个序列转换成非严格递增序列的最小花费 POJ 3666

    //把一个序列转换成非严格递增序列的最小花费 POJ 3666 //dp[i][j]:把第i个数转成第j小的数,最小花费 #include <iostream> #include < ...

  4. 第四届CCF软件能力认证(CSP2015) 第五题(最小花费)题解

    [问题描述] C国共有$n$个城市.有$n-1$条双向道路,每条道路连接两个城市,任意两个城市之间能互相到达.小R来到C国旅行,他共规划了$m$条旅行的路线, 第$i$条旅行路线的起点是$s_i$,终 ...

  5. 九度OJ 1086 最小花费--动态规划

    题目地址:http://ac.jobdu.com/problem.php?pid=1086 题目描述: 在某条线路上有N个火车站,有三种距离的路程,L1,L2,L3,对应的价格为C1,C2,C3.其对 ...

  6. hdoj 3072 Intelligence System【求scc&&缩点】【求连通所有scc的最小花费】

    Intelligence System Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Othe ...

  7. ccf 201503-5 最小花费 这题交上去只有10分嗨!求大佬的题解啊

    问题描述 C国共有n个城市.有n-1条双向道路,每条道路连接两个城市,任意两个城市之间能互相到达.小R来到C国旅行,他共规划了m条旅行的路线,第i条旅行路线的起点是si,终点是ti.在旅行过程中,小R ...

  8. [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 ...

  9. 1344:【例4-4】最小花费 dijkstra

    1344:[例4-4]最小花费 Dijkstra (1)a [ i ] [ j ] 存转账率(..转后所得率..) (2)dis [ i ] 也就是 a [ 起点 ] [ i ] (3)f [ i ] ...

随机推荐

  1. CCF(URL映射:80分):字符串处理+模拟

    URL映射 CCF201803-3 #include<iostream> #include<cstdio> #include<cstring> #include&l ...

  2. 虚拟机安装centos系统【史上最详细的】

    因为文章中有很多的图片,在博客园中还需要单张上传,所以使用了将markdown的文件链接存入网盘中让大家下载 windows系统请使用Typora软件打开 如果不知道Typora是什么软件,请在百度搜 ...

  3. Jmeter +Jenkins +Ant 集成发送邮件报告

    [TOC] 一.什么是接口测试? 接口测试是测试系统组件间接口的一种测试.接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点.测试的重点是要检查数据的交换,传递和控制管理过程,以及系 ...

  4. golang 二维平面求多重遮挡三角形总面积

    解决问题描述:二维平面有很多三角形错落,可能会相互叠加落在一起,也可能互相远离.目标求出这些三角形的总占地面积. 我最开始想的解决方案是用总面积-总重叠面积 = 总占地面积.后来实现起来发现当面临多次 ...

  5. HDU-6862 Hexagon (2020HDU 多校 D8 H)

    1008 题意:半径为n的六边形(由半径为1的小六边形组成),从某一个小六边形出发有六个方向,找到一条转向次数最多的路径(用方向表示)遍历所有的六边形(一个六边形只访问一次). 题解:先画出n=3/4 ...

  6. P1047_校门外的树(JAVA语言)

    题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米. 我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置: 数轴上的每个整数点,即0,1,2,-,L都种 ...

  7. PTA 输出数组元素

    7-3 输出数组元素 (15 分)   本题要求编写程序,对顺序读入的n个整数,顺次计算后项减前项之差,并按每行三个元素的格式输出结果. 输入格式: 输入的第一行给出正整数n(1).随后一行给出n个整 ...

  8. SpringBoot-03 yaml+JSR303

    SpringBoot-03 yaml+JSR303 Yaml 1.配置文件 SpringBoot使用一个全局的配置文件 , 配置文件名称是固定的 YAML是 "YAML Ain't a Ma ...

  9. Java学习之随机数的用法

    •前言 随机数的产生在一些代码中很常用,也是我们必须要掌握的. 而 Java 中产生随机数的方法主要有三种: new Random() Math.random() currentTimeMillis( ...

  10. 学习C#第二天

    变量 变量是什么? 在数学中,我们对变量的概念有一定的了解和认识,如y=x^2,其中,x,y都是变量. 定义 一个变量就是存储区(内存)中的一个存储单元 变量的声明及初始化 使用变量的步骤 声明一个变 ...