HDU-1260-Tickets(线性DP,DP入门)
Tickets
Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 7996    Accepted Submission(s): 4063
Problem Description
Jesus, what a great movie! Thousands of people are rushing to the cinema. However, this is really a tuff time for Joe who sells the film tickets. He is wandering when could he go back home as early as possible.
A good approach, reducing the total time of tickets selling, is let adjacent people buy tickets together. As the restriction of the Ticket Seller Machine, Joe can sell a single ticket or two adjacent tickets at a time.
Since you are the great JESUS, you know exactly how much time needed for every person to buy a single ticket or two tickets for him/her. Could you so kind to tell poor Joe at what time could he go back home as early as possible? If so, I guess Joe would full of appreciation for your help.
Input
There are N(1<=N<=10) different scenarios, each scenario consists of 3 lines:
1) An integer K(1<=K<=2000) representing the total number of people;
2) K integer numbers(0s<=Si<=25s) representing the time consumed to buy a ticket for each person;
3) (K-1) integer numbers(0s<=Di<=50s) representing the time needed for two adjacent people to buy two tickets together.
Output
For every scenario, please tell Joe at what time could he go back home as early as possible. Every day Joe started his work at 08:00:00 am. The format of time is HH:MM:SS am|pm.
Sample Input
20 25
40
Sample Output
08:00:40 am
08:00:08 am
找到状态转移方程: dp[i] = min( dp[i-1] + a[i], dp[i-2] + b[i]); 就很容易解决问题了
#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
int main()
{
    int a[2018], b[2018], dp[2018];
    int i, n, k;
    cin >> n;
    while( n-- )
    {
        cin >> k;
        for( i=0; i<k; i++ )
            cin >> a[i];
        for( i=1; i<k; i++ )
            cin >> b[i];
        dp[0] = a[0];
        dp[1] = min( dp[0] + a[1], b[1] );
        for( i=2; i<k; i++ )
            dp[i] = min( dp[i-1] + a[i], dp[i-2] + b[i]);
        int time = dp[k-1];
        int h, m, s;
        h = 8 + time / 3600;
        m = time % 3600 / 60;
        s = time % 60;
        if( h > 12 )
        {
            h = h - 12;
            printf("%02d:%02d:%02d pm\n", h, m, s);
        }
        else
            printf("%02d:%02d:%02d am\n", h, m, s);
    }
    return 0;
}
HDU-1260-Tickets(线性DP,DP入门)的更多相关文章
- HDU 1260 Tickets (普通dp)
		传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1260 Tickets Time Limit: 2000/1000 MS (Java/Others) ... 
- HDU 1260 Tickets(基础dp)
		一开始我对这个题的题意理解有问题,居然超时了,我以为是区间dp,没想到是个水dp,我泪奔了.... #include<stdio.h> #include<string.h> # ... 
- HDU 1260 Tickets(简单dp)
		Tickets Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Sub ... 
- 【万能的搜索,用广搜来解决DP问题】ZZNU -2046 : 生化危机  /  HDU  1260:Tickets
		2046 : 生化危机 时间限制:1 Sec内存限制:128 MiB提交:19答案正确:8 题目描述 当致命的T病毒从Umbrella Corporation 逃出的时候,地球上大部分的人都死去了. ... 
- HDU 1260 Tickets DP
		http://acm.hdu.edu.cn/showproblem.php?pid=1260 用dp[i]表示处理到第i个的时候用时最短. 那么每一个新的i,有两个选择,第一个就是自己不和前面的组队, ... 
- E - Max Sum Plus Plus Plus HDU - 1244 (线性区间DP)
		题目大意: 值得注意的一点是题目要求的是这些子段之间的最大整数和.注意和Max Sum Plus Plus这个题目的区别. 题解: 线性区间DP,对每一段考虑取或者不取.定义状态dp[i][j]指的 ... 
- 题解报告:hdu 1260 Tickets
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1260 Problem Description Jesus, what a great movie! T ... 
- HDU - 1260  Tickets  【DP】
		题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=1260 题意 有N个人来买电影票 因为售票机的限制 可以同时 卖一张票 也可以同时卖两张 卖两张的话 两 ... 
- hdu  1260 Tickets
		http://acm.hdu.edu.cn/showproblem.php?pid=1260 题目大意:n个人买票,每个人买票都花费时间,相邻的两个人可以一起买票以节约时间: 所以一个人可以自己买票也 ... 
- HDU 1260 Tickets (动规)
		Tickets Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Su ... 
随机推荐
- 21-py3 发邮件
			Python3 SMTP发送邮件 SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式. p ... 
- mybatis逆向工程的注意事项:mapper文件内容不是覆盖而是追加
			XXXMapper.xml文件已经存在时,如果进行重新生成则mapper.xml文件内容不被覆盖而是进行内容追加,结果导致mybatis解析失败. 解决方法:删除原来已经生成的mapper xml文件 ... 
- memcache can't run as root without the -u switch
			memcached是一款高速.分布式的内存缓存系统.其官方主页在http://www.danga.com/memcached/1.安装前的准备要安装memcached,需要有libevent的支持.c ... 
- Java_String_Arrays_Character_BigDecimal_Calendar_Math_System
			1.String package cn.itcast_01; /* * Scanner:用于接收键盘录入数据. * * 前面的时候: * A:导包 * B:创建对象 * C:调用方法 * * Sy ... 
- nignx reload的时候报错invalid PID number
			第一种思路是从PID号着手,提示无效PID号时nginx.pid文件为空,将进程的PID号追加到空的nginx.pid上,问题解决: 还有问题,请参考:https://www.cnblogs.com/ ... 
- c++沉思录中 对字符串进行围边 横向连接 竖向连接操作的练习
			// MyPics.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <string> #include < ... 
- 如何用Python实现常见机器学习算法-4
			四.SVM支持向量机 1.代价函数 在逻辑回归中,我们的代价为: 其中: 如图所示,如果y=1,cost代价函数如图所示 我们想让,即z>>0,这样的话cost代价函数才会趋于最小(这正是 ... 
- Text Relatives
			[Text Relatives] With TextKit the resources at your disposal range from framework objects—such as te ... 
- Workflow笔记2——状态机工作流(转)
			出处:http://www.cnblogs.com/jiekzou/p/6192813.html 在上一节Workflow笔记1——工作流介绍中,介绍的是流程图工作流,后来微软又推出了状态机工作流,它 ... 
- PowerDesigner工具建表步骤
			以商场VIP系统中的表为例 先建立管理员用户表 1.双击打开PowerDesigner工具,点File 选择 New Model 打开如下图,选择标红部分,点击OK 2点击选择标红部位Entity ... 
