题意:

      有一个加工厂加工月饼的,这个工厂一共开业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. 话说 synchronized

    一.前言 ​ 说起java的锁呀,我们先想到的肯定是synchronized[ˈsɪŋ krə naɪ zd]了 ,这个单词很拗口,会读这个单词在以后的面试中很加分(我面试过一些人 不会读 ,他们说的 ...

  2. Linux下找出吃内存的方法总结

    Linux下查询进程占用的内存方法总结,假设现在有一个「php-cgi」的进程 ,进程id为「25282」. 现在想要查询该进程占用的内存大小.linux命令行下有很多的工具进行查看,现总结常见的几种 ...

  3. phpMyAdmin Transformation 任意文件包含/远程代码执行漏洞

    漏洞参考 https://yq.aliyun.com/articles/679633 国外提供了一个在线测试的靶场     默认密码  root  toor https://www.vsplate.c ...

  4. 解决 Ant Design Modal 中的 Select 选项框不能显示的问题

    antd 的 select 在 modal 里不能显示候选框 代码示例 <a-modal> <a-select> <!-- options --> </a-s ...

  5. 选择 FreeBSD 而不是 Linux 的技术性原因2

    ZFSZFS 文件系统是 FreeBSD 上的一等公民.这不仅意味着可以在 ZFS 上安装根目录,安装程序也支持这一点,而且还意味着很多基础系统工具都已经紧密地集成或构建了对 ZFS 的支持.在 Fr ...

  6. slickgrid ( nsunleo-slickgrid ) 1 开篇有益

    slickgrid (nsunleo-slickgrid)  1 开篇有益  作为专职的程序猿,自认为是老菜鸟或老民工,以前一直在某浪上写博客,上知天文,下达地理.做了N年的.net,又转Java,从 ...

  7. Java面向对象(一些问题)

    2. Java 面向对象 2.1. 类和对象 2.1.1. 面向对象和面向过程的区别 面向过程 :面向过程性能比面向对象高. 因为类调用时需要实例化,开销比较大,比较消耗资源,所以当性能是最重要的考量 ...

  8. 2019HDU多校第七场 HDU6646 A + B = C 【模拟】

    一.题目 A + B = C 二.分析 比较考验码力的题. 对于$c$,因为首位肯定不为0,那么$a$或者$b$至少有一个最高位是和$c$平齐的,或者少一位(相当于$a$+$b$进位得到). 那么这里 ...

  9. 谜题(JAVA语言)

    package 第三章习题; /*  * 有一个5*5的网络,其中恰好有一个格子是空的,其他格子各有一个字母.  * 一个有4种指令:A, B, L, R, 分别表示把空格上.下.左.右的相邻字母移到 ...

  10. 《Selenium自动化测试实战:基于Python》之 Selenium IDE插件的安装与使用

    第3章  Selenium IDE插件的安装与使用 京东:https://item.jd.com/13123910.html 当当:http://product.dangdang.com/292045 ...