P1877 [HAOI2012]音量调节

题目描述

一个吉他手准备参加一场演出。他不喜欢在演出时始终使用同一个音量,所以他决定每一首歌之前他都需要改变一次音量。在演出开始之前,他已经做好一个列表,里面写着每首歌开始之前他想要改变的音量是多少。每一次改变音量,他可以选择调高也可以调低。

音量用一个整数描述。输入文件中整数beginLevel,代表吉他刚开始的音量,整数maxLevel,代表吉他的最大音量。音量不能小于0也不能大于maxLevel。输入中还给定了n个整数c1,c2,c3,...,cn,表示在第i首歌开始之前吉他手想要改变的音量是多少。

吉他手想以最大的音量演奏最后一首歌,你的任务是找到这个最大音量是多少。

输入输出格式

输入格式:

第一行依次为三个整数n, beginLevel, maxLevel。

第二行依次为n个整数 c1,c2,c3,...,cn。

数据规模:

1<=n<=50, 1<=ci<=maxLevel, 1<=maxLevel<=1000, 0<=beginLevel<=maxLevel

输出格式:

输出演奏最后一首歌的最大音量。如果吉他手无法避免音量低于0或者高于maxLevel,输出-1。

输入输出样例

输入样例#1:

  1. 3 5 10
  2. 5 3 7
输出样例#1:

  1. 10
  2.  
  3. 刚上来以为是背包。。
    结果并不能满足无后效性
    最后发现每次音量必定调节而且必须按顺序调节
    更加否定了背包。。
  4.  
  5. 这就是一个普通的dp而已。。。
    状态:[i][j]表示第i次调音可否达到音量j
    转移:f[i][j - c[i]] = 1 当且仅当f[i-1][j] = 1 &&j - c[i] > 0
    f[i][j + c[i]] = 1 当且仅当f[i-1][j] = 1 &&j + c[i] > 0 &&  j - c[i] <= maxlevel
    初始状态:f[0][beginlevel] = true;
    可以这样考虑:i = 1时会去看i = 0时哪一个是true,由于有一个初始音量beginlevel,必须从beginlevel开始转移,也就是说此时仅有j = beginlevel 时才符合要求
  6.  
  7. 上代码
  1. #include <iostream>
  2. #include <cstdio>
  3. #include <cstdlib>
  4. #include <cstring>
  5. #include <algorithm>
  6.  
  7. const int MAXN = 50 + 10;
  8. const int MAXLEVEL = 1000 + 10;
  9.  
  10. #define max(a,b) ((a) < (b) ? (b) : (a))
  11. #define min(a,b) ((a) < (b) ? (a) : (b))
  12.  
  13. inline int read()
  14. {
  15. int x = 0; char ch = getchar();char c = ch;
  16. while(ch > '9' || ch < '0')c = ch, ch = getchar();
  17. while(ch <= '9' && ch >= '0')x = x * 10 + ch - '0', ch = getchar();
  18. if(c == '-')return -1 * x;
  19. return x;
  20. }
  21. int n,beginlevel,maxlevel;
  22. int c[MAXN];
  23. bool f[MAXN][MAXLEVEL];
  24. int sum;
  25.  
  26. int main()
  27. {
  28. n = read();beginlevel = read();maxlevel = read();
  29. sum += beginlevel;
  30. for(int i = 1;i <= n;i ++)
  31. {
  32. c[i] = read();
  33. sum += c[i];
  34. }
  35. f[0][beginlevel] = true;
  36. for(int i = 1;i <= n;i ++)
  37. {
  38. for(int j = 0;j <= maxlevel;j ++)
  39. {
  40. if(j - c[i] >= 0 && f[i-1][j - c[i]] && j - c[i] <= maxlevel)
  41. {
  42. f[i][j] = true;
  43. }
  44. if(j + c[i] >= 0 && f[i-1][j + c[i]] && j + c[i] <= maxlevel)
  45. {
  46. f[i][j] = true;
  47. }
  48. }
  49. }
  50. int ans = -1;
  51. for(int i = maxlevel;i >= 0;i --)
  52. {
  53. if(f[n][i])
  54. {
  55. ans = i;
  56. printf("%d", ans);
  57. return 0;
  58. }
  59. }
  60. printf("-1");
  61. return 0;
  62. }

洛谷P1877 [HAOI2012]音量调节 [2017年4月计划 动态规划05]的更多相关文章

  1. 洛谷 P1877 [HAOI2012]音量调节

    P1877 [HAOI2012]音量调节 题目描述 一个吉他手准备参加一场演出.他不喜欢在演出时始终使用同一个音量,所以他决定每一首歌之前他都需要改变一次音量.在演出开始之前,他已经做好一个列表,里面 ...

  2. 洛谷—— P1877 [HAOI2012]音量调节

    https://www.luogu.org/problem/show?pid=1877#sub 题目描述 一个吉他手准备参加一场演出.他不喜欢在演出时始终使用同一个音量,所以他决定每一首歌之前他都需要 ...

  3. 洛谷P1164 小A点菜 [2017年4月计划 动态规划08]

    P1164 小A点菜 题目背景 uim神犇拿到了uoi的ra(镭牌)后,立刻拉着基友小A到了一家……餐馆,很低端的那种. uim指着墙上的价目表(太低级了没有菜单),说:“随便点”. 题目描述 不过u ...

  4. 洛谷P1244 [NOI2000] 青蛙过河 [2017年4月计划 动态规划07]

    P1244 青蛙过河 题目描述 有一条河,左边一个石墩(A区)上有编号为1,2,3,4,…,n的n只青蛙,河中有k个荷叶(C区),还有h个石墩(D区),右边有一个石墩(B区),如下图所示.n只青蛙要过 ...

  5. 洛谷P2347 砝码称重 [2017年4月计划 动态规划01]

    P2347 砝码称重 题目描述 设有1g.2g.3g.5g.10g.20g的砝码各若干枚(其总重<=1000), 输入输出格式 输入格式: 输入方式:a1 a2 a3 a4 a5 a6 (表示1 ...

  6. 洛谷P1390 公约数的和 [2017年6月计划 数论12]

    P1390 公约数的和 题目描述 有一天,TIBBAR和LXL比赛谁先算出1~N这N个数中每任意两个不同的数的最大公约数的和.LXL还在敲一个复杂而冗长的程序,争取能在100s内出解.而TIBBAR则 ...

  7. 洛谷P1573 栈的操作 [2017年6月计划 数论11]

    P1573 栈的操作 题目描述 现在有四个栈,其中前三个为空,第四个栈从栈顶到栈底分别为1,2,3,…,n.每一个栈只支持一种操作:弹出并 压入.它指的是把其中一个栈A的栈顶元素x弹出,并马上压入任意 ...

  8. 洛谷P2429 制杖题 [2017年6月计划 数论10]

    P2429 制杖题 题目描述 求不大于 m 的. 质因数集与给定质数集有交集的自然数之和. 输入输出格式 输入格式: 第一行二个整数 n,m. 第二行 n 个整数,表示质数集内的元素 p[i]. 输出 ...

  9. 洛谷P1147 连续自然数和 [2017年6月计划 数论01]

    P1147 连续自然数和 题目描述 对一个给定的自然数M,求出所有的连续的自然数段,这些连续的自然数段中的全部数之和为M. 例子:1998+1999+2000+2001+2002 = 10000,所以 ...

随机推荐

  1. 牛人blog 头脑风暴 (持续添加与更新)

    Http协议详解 http://www.cnblogs.com/TankXiao/archive/2012/02/13/2342672.html android 实现分享功能两种方法 http://w ...

  2. gdal在redhat4.4下安装

    GDAL(Geospatial Data Abstraction Library)是一个在X/MIT许可协议下的开源栅格空间数据转换库.它利用抽象数据模型来表达所支持的各种文件格式.它还有一系列命令行 ...

  3. HDU--2126 Buy the souvenirs(二维01背包)

    题目http://acm.hdu.edu.cn/showproblem.php?pid=2126 分析:有两个要求,一是计算最多可以选多少中纪念品:而是计算选最多纪念品的方案有多少种, 即统计最优方案 ...

  4. Spring整合JUnit单元测试

    必须先有JUnit的环境(已经导入了Junit4的开发环境) 1.导入jar包 2.在测试类上添加注解 @RunWith(SpringJUnit4ClassRunner.class) @Context ...

  5. mac上安装软件后,桌面上软件的图标如何去掉?

    桌面上的图标是软件的镜像包,默认安装以镜像形式,你选中它,按command+e 就可以推掉它

  6. spfa模版

    #include<bits/stdc++.h> using namespace std; int n,m;//点边 int beginn; ],v[],w[]; ],nextt[]; ]; ...

  7. php循环语句(二)

    for 循环 for 循环用于您预先知道脚本需要运行的次数的情况. 语法 for (初始值; 条件; 增量) { 要执行的代码; } 参数: 初始值:主要是初始化一个变量值,用于设置一个计数器(但可以 ...

  8. 微信小程序——页面滑动事件

    wxml: <view id="id" class = "ball" bindtap = "handletap" bindtouchs ...

  9. Joining Byte Blocks(哈希+带花树)

    题目链接 Problem Statement As you are probably aware, the Internet protocols specify a canonical byte or ...

  10. Filter - 全局编码 (装饰者模式)

    Tomcat7以前需要处理get乱码,tomcat8以后不需要处理get乱码,因为tomcat内部会处理. 乱码原因: package cn.itcast.web.filter; import jav ...