题意:

      有一个加工厂加工月饼的,这个工厂一共开业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. 12. Vue搭建本地服务

    一. 搭建本地服务器 本地服务可以提高开发效率. webpack不需要每次都打包, 就可以看到修改后的效果. 本地服务器基于node.js搭建, 内部使用二十express框架. 可以实现让浏览器自动 ...

  2. Graylog日志管理单机部署、日志节点的Sidecar配置以及简单的警告事件邮件发送

    应该是上个星期的上个星期,下了个任务,要做Graylog的部署以及文档,emmm....带log,肯定是和日志有关系了呗,不过也没听过啊,去搜了一下,确实,也不少帖子博客相关的都有安装部署,还是yum ...

  3. Fastjson1.2.24RCE漏洞复现

    Fastjson1.2.24RCE漏洞复现 环境搭建 这里用的Vulhub靶场 cd /vulhub/fastjson/1.2.24-rce docker-compose up -d 报错 ERROR ...

  4. Python开发环境从零搭建-03-安装Python解释器并配置

    想要从零开始搭建一个Python的开发环境说容易也容易 说难也能难倒一片开发人员,在接下来的一系列视频中,会详细的讲解如何一步步搭建python的开发环境 本文章是搭建环境的第3篇 讲解的内容是:安装 ...

  5. C语言float和double输入问题

    统计给定的n个数中,负数.零和正数的个数. Input    输入数据有多组,每组占一行,每行的第一个数是整数n(n<100),表示需要统计的数值的个数,然后是n个实数:如果n=0,则表示输入结 ...

  6. WinForm的Socket实现简单的聊天室 IM

    1:什么是Socket 所谓套接字(Socket),就是对网络中不同主机上的应用进程之间进行双向通信的端点的抽象. 一个套接字就是网络上进程通信的一端,提供了应用层进程利用网络协议交换数据的机制. 从 ...

  7. 攻防世界 reverse 进阶 8-The_Maya_Society Hack.lu-2017

    8.The_Maya_Society Hack.lu-2017 在linux下将时间调整为2012-12-21,运行即可得到flag. 下面进行分析 1 signed __int64 __fastca ...

  8. Logback简介及配置文件logback.xml详解

    logback简介及配置文件说明 @author:wangyq @date:2021年3月31日 logback简介 ​ Logback是由log4j创始人设计的另一个开源日志组件,官方网站: htt ...

  9. irace package -- 参数调优神器

    目录 1. irace 是什么 2. 安装 irace 3. irace 的运行机制 4. irace 的配置环境 4.1. parameters 4.2. target algorithm runn ...

  10. 最短路径(Floyd算法)

    声明:图片及内容基于https://www.bilibili.com/video/BV1oa4y1e7Qt?from=articleDetail 多源最短路径的引入 Floyd算法 原理 加入a: 加 ...