题目链接

http://acm.hdu.edu.cn/showproblem.php?pid=1260

题意

有N个人来买电影票 因为售票机的限制 可以同时 卖一张票 也可以同时卖两张 卖两张的话 两个人必须是相邻的

给出 N 个 价格 是 一个一个买的时间花费

给出 N - 1个价格 是 相邻的两个人一起买的时间花费 求出 最小的时间花费

思路

dp[i] 表示 卖到当前这个人的时间花费

状态转移方程

dp[i] = min(dp[i - 2] + b[i - 1], dp[i - 1] + a[i])

当前这个人的时间花费 他 可以单独买 就是 dp[i - 1] + a[i]

也可以 和 上一个人 一起买 就是 dp[i - 2] + b[i - 1] 去最优解

AC代码

  1. #include <cstdio>
  2. #include <cstring>
  3. #include <ctype.h>
  4. #include <cstdlib>
  5. #include <cmath>
  6. #include <climits>
  7. #include <ctime>
  8. #include <iostream>
  9. #include <algorithm>
  10. #include <deque>
  11. #include <vector>
  12. #include <queue>
  13. #include <string>
  14. #include <map>
  15. #include <stack>
  16. #include <set>
  17. #include <list>
  18. #include <numeric>
  19. #include <sstream>
  20. #include <iomanip>
  21. #include <limits>
  22. #define CLR(a, b) memset(a, (b), sizeof(a))
  23. #define pb push_back
  24. using namespace std;
  25. typedef long long ll;
  26. typedef long double ld;
  27. typedef unsigned long long ull;
  28. typedef pair <int, int> pii;
  29. typedef pair <ll, ll> pll;
  30. typedef pair<string, int> psi;
  31. typedef pair<string, string> pss;
  32. const double PI = acos(-1.0);
  33. const double E = exp(1.0);
  34. const double eps = 1e-8;
  35. const int INF = 0x3f3f3f3f;
  36. const int maxn = 2e3 + 5;
  37. const int MOD = 1e9 + 7;
  38. int a[maxn];
  39. int b[maxn];
  40. int dp[maxn];
  41. int main()
  42. {
  43. int t;
  44. cin >> t;
  45. while (t--)
  46. {
  47. int n;
  48. scanf("%d", &n);
  49. for (int i = 1; i <= n; i++)
  50. scanf("%d", &a[i]);
  51. for (int i = 1; i < n; i++)
  52. scanf("%d", &b[i]);
  53. CLR(dp, 0);
  54. dp[0] = 0;
  55. dp[1] = a[1];
  56. for (int i = 2; i <= n; i++)
  57. {
  58. dp[i] = min(dp[i - 2] + b[i - 1], dp[i - 1] + a[i]);
  59. }
  60. int a = 8, b = 0, c = dp[n];
  61. b += c / 60;
  62. c %= 60;
  63. a += b / 60;
  64. b %= 60;
  65. printf("%02d:%02d:%02d am\n", a, b, c);
  66. }
  67. }

HDU - 1260 Tickets 【DP】的更多相关文章

  1. hdoj 1260 Tickets【dp】

    Tickets Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Sub ...

  2. hdu 2845——Beans——————【dp】

    Beans Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  3. 【万能的搜索,用广搜来解决DP问题】ZZNU -2046 : 生化危机 / HDU 1260:Tickets

    2046 : 生化危机 时间限制:1 Sec内存限制:128 MiB提交:19答案正确:8 题目描述 当致命的T病毒从Umbrella Corporation 逃出的时候,地球上大部分的人都死去了. ...

  4. 【DP】HDU 1260

    HDU 1260 Tickets 题意:有N个人要买票,你可以一个一个人卖票,时间分别为Xs,也可以相邻两个人一起卖票,时间为Ys,从早上八点开始卖票,问你何时最早将N个人的票卖完. 思路:解决情况是 ...

  5. HDOJ_1087_Super Jumping! Jumping! Jumping! 【DP】

    HDOJ_1087_Super Jumping! Jumping! Jumping! [DP] Time Limit: 2000/1000 MS (Java/Others) Memory Limit: ...

  6. Kattis - honey【DP】

    Kattis - honey[DP] 题意 有一只蜜蜂,在它的蜂房当中,蜂房是正六边形的,然后它要出去,但是它只能走N步,第N步的时候要回到起点,给出N, 求方案总数 思路 用DP 因为N == 14 ...

  7. HDOJ 1423 Greatest Common Increasing Subsequence 【DP】【最长公共上升子序列】

    HDOJ 1423 Greatest Common Increasing Subsequence [DP][最长公共上升子序列] Time Limit: 2000/1000 MS (Java/Othe ...

  8. HDOJ 1501 Zipper 【DP】【DFS+剪枝】

    HDOJ 1501 Zipper [DP][DFS+剪枝] Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Ja ...

  9. HDOJ 1257 最少拦截系统 【DP】

    HDOJ 1257 最少拦截系统 [DP] Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...

随机推荐

  1. CI框架基础知识

    调用一个视图 a.调用一个视图 $this->load->view('视图文件名'); b.调用多个视图 $this->load->view('index_h'); $this ...

  2. EclipseADT(4.2) 安装 STS(spring )

    因为ADT 版本是4.2, 网上找了一圈 from: https://spring.io/blog/2012/03/14/early-access-springsource-tool-suite-fo ...

  3. Linux下的定时任务Crontab

    通过crontab -e写入定时任务的指令,一行为一项任务. 任务模式是时间克龙表达式+命令形式. 如: 2 0,6,12,18 * * * perl /root/restarttomcat.pl p ...

  4. void f(int(&amp;p)[3]){} 和void f(int(*p)[3]){}的差别

    #include<iostream> using namespace std; void f(int(&p)[3]){          cout<<p[0]<& ...

  5. JAVA Eclipse创建Android程序如何实现MainActivity和Fragment相互传递数据

    最简单的方法是直接强制生成一个MainActivity的实例,然后可以执行其中的方法,当然也是可以传递参数的 更加复杂的用法可以参考: http://blog.csdn.net/huangyabin0 ...

  6. JSON 值转换

    var Txt = '{"a":"1","b":"5","c":"5",&quo ...

  7. python:字符串的连接

    python中有很多字符串连接方式,今天在写代码,顺便总结一下: 最原始的字符串连接方式:str1 + str2 python 新字符串连接语法:str1, str2 奇怪的字符串方式:str1 st ...

  8. Java使用笔记之对象比较

    1.关于java对象的比较,经常会遇见比较某个两个对象的多个属性是否相等,可以通过重写对象equals方法来实现. 比如有两个User,如果姓名和年龄相等的话,我们就可以认为他们重复的数据.那么我们就 ...

  9. win10多用户远程登录

    实现效果:不同的电脑可以同时登录一台windows主机,但是必须使用不同的账号 首先,我们来创建一个新用户 点击设置,搜索用户 点击下一步,一个普通用户就创建完成了. 然后,打开远程设置,右键此电脑, ...

  10. Android中读取图片EXIF元数据之metadata-extractor的使用

    一.引言及介绍 近期在开发中用到了metadata-extractor-xxx.jar 和 xmpcore-xxx.jar这个玩意, 索性查阅大量文章了解学习,来分享分享. 本身工作也是常常和处理大图 ...