[HAOI2012]音量调节

题目链接

吐槽-没看到可以调大调小,WA了一小时。很伤心,所以在此希望大家记得仔细读题!!!

思考

01背包问题是 一个物品拿或者不拿中求最大值的问题

这道题目就是 音量增加或者减少中求最大值的问题

但是如果生搬硬套01背包的方程用在这里肯定是不合适的。

在这里,我们想对于每次调节,也就是两种可能 在上次的基础上调大,或者是调小。但是调大不能超过上限,调小不能超过下限。

让我们再分析分析样例:

3 5 10

5 3 7

第一次调节 只能从 5开始 调小的话就是0 调大的话就是10

第二次调节 先分析0 调小不可以 调大只能是3  在分析10 调小是7 调大不可以

第三次调节 先分析3 调小不可以 调大是10 再分析7 调小是0 调大是不可以

是不是隐隐约约能摸索出这个转移方程了?

对没错,方程是 用二维bool型数组来DP,f[i][j]=true表示第i首歌音量为j可行,DP方程为:

if((f[i-1][j+c[i]]==true&&j+c[i]<=maxL)||(f[i-1][j-c[i]]==true&&j-c[i]>=0)) f[i][j]=true;

关键是f[i-1][j+c[i]] 和 f[i-1][j-c[i]]这两个,要仔细推敲。

初始值f[0][初始值]=1

最后再从大到小遍历 最后一次 调节时的最大值,如果存在输出。如果不存在则输出-1.

 1 #include <cstdio>
 2 const int maxn=1005;
 3 int n,m,MAX,c[maxn];
 4 bool dp[maxn][maxn];
 5 int main(){
 6     scanf("%d%d%d",&n,&m,&MAX);
 7     for(int i=1;i<=n;i++) scanf("%d",&c[i]);
 8     dp[0][m]=1;
 9     for(int i=1;i<=n;i++)
10         for(int j=0;j<=MAX;j++){
11             if( (dp[i-1][j+c[i]] && j+c[i]<=MAX) || ( dp[i-1][j-c[i]] && j-c[i]>=0))
12             dp[i][j]=1;
13         }
14     for(int i=MAX;i>=0;i--){
15         if(dp[n][i]) {
16             printf("%d\n",i);
17             return 0;
18         }
19     }
20     printf("-1");
21     return 0;
22 }

代码实现

时间: 2024-10-24 14:39:02

[HAOI2012]音量调节的相关文章

洛谷 P1877 [HAOI2012]音量调节

P1877 [HAOI2012]音量调节 题目描述 一个吉他手准备参加一场演出.他不喜欢在演出时始终使用同一个音量,所以他决定每一首歌之前他都需要改变一次音量.在演出开始之前,他已经做好一个列表,里面写着每首歌开始之前他想要改变的音量是多少.每一次改变音量,他可以选择调高也可以调低. 音量用一个整数描述.输入文件中整数beginLevel,代表吉他刚开始的音量,整数maxLevel,代表吉他的最大音量.音量不能小于0也不能大于maxLevel.输入中还给定了n个整数c1,c2,c3,...,cn

bzoj-2748 2748: [HAOI2012]音量调节(dp)

题目链接: 2748: [HAOI2012]音量调节 Time Limit: 3 Sec  Memory Limit: 128 MB Description 一个吉他手准备参加一场演出.他不喜欢在演出时始终使用同一个音量,所以他决定每一首歌之前他都要改变一次音量.在演出开始之前,他已经做好了一个列表,里面写着在每首歌开始之前他想要改变的音量是多少.每一次改变音量,他可以选择调高也可以调低.音量用一个整数描述.输入文件中给定整数beginLevel,代表吉他刚开始的音量,以及整数maxLevel,

BZOJ 2748: [HAOI2012]音量调节 dp

2748: [HAOI2012]音量调节 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/problem.php?id=2748 Description 一个吉他手准备参加一场演出.他不喜欢在演出时始终使用同一个音量,所以他决定每一首歌之前他都要改变一次音量.在演出开始之前,他已经做好了一个列表,里面写着在每首歌开始之前他想要改变的音量是多少.每一次改变音量,他可以选择调高也可以调低.音量

2748: [HAOI2012]音量调节

2748: [HAOI2012]音量调节 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 719  Solved: 475[Submit][Status] Description 一个吉他手准备参加一场演出.他不喜欢在演出时始终使用同一个音量,所以他决定每一首歌之前他都要改变一次音量.在演出开始之前,他已经做好了一个列表,里面写着在每首歌开始之前他想要改变的音量是多少.每一次改变音量,他可以选择调高也可以调低.音量用一个整数描述.输入文件中给定整数b

BZOJ 2748: [HAOI2012]音量调节【二维dp,枚举】

2748: [HAOI2012]音量调节 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 2010  Solved: 1260[Submit][Status][Discuss] Description 一个吉他手准备参加一场演出.他不喜欢在演出时始终使用同一个音量,所以他决定每一首歌之前他都要改变一次音量.在演出开始之前,他已经做好了一个列表,里面写着在每首歌开始之前他想要改变的音量是多少.每一次改变音量,他可以选择调高也可以调低. 音量用一个整数描

bzoj 2748: [HAOI2012]音量调节

2748: [HAOI2012]音量调节 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 872  Solved: 577[Submit][Status][Discuss] Description 一个吉他手准备参加一场演出.他不喜欢在演出时始终使用同一个音量,所以他决定每一首歌之前他都要改变一次音量.在演出开始之前,他已经做好了一个列表,里面写着在每首歌开始之前他想要改变的音量是多少.每一次改变音量,他可以选择调高也可以调低.音量用一个整数描述.输

Bzoj 2748: [HAOI2012]音量调节 动态规划

2748: [HAOI2012]音量调节 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 1234  Solved: 777[Submit][Status][Discuss] Description 一个吉他手准备参加一场演出.他不喜欢在演出时始终使用同一个音量,所以他决定每一首歌之前他都要改变一次音量.在演出开始之前,他已经做好了一个列表,里面写着在每首歌开始之前他想要改变的音量是多少.每一次改变音量,他可以选择调高也可以调低.音量用一个整数描述.

bzoj2748: [HAOI2012]音量调节(背包)

2748: [HAOI2012]音量调节 题目:传送门 题解: sb省选题..呵呵一眼背包: f[i][j]表示第i时刻能否为音量j 代码: 1 #include<cstdio> 2 #include<cstring> 3 #include<cstdlib> 4 #include<cmath> 5 #include<algorithm> 6 using namespace std; 7 int n,st,mx; 8 int a[55]; 9 bo

P1877 [HAOI2012]音量调节

P1877 [HAOI2012]音量调节 题解 目录: 1. solution 1 普通dfs  60pt 2. solution 2 记忆化搜索 100pt 3. solution 3 到达型 01 背包 4. PS            CE 的原因 solution 1 普通dfs  60pt dfs 暴搜,pos 记录当前到了第几首歌,level 记录当前的音量 一个小剪枝 由于每换一首歌都要调节音量,也就是要么 + 下一首音量,要么 - 下一首歌音量.那么当我们发现无论是上调音量还是下

[bzoj2748][HAOI2012]音量调节_动态规划_背包dp

音量调节 bzoj-2748 HAOI-2012 题目大意:有一个初值,给你n个$\delta$值,求最后不超过给定的限制的情况下的改变的最大值.每个$\delta$值可以+也可以-. 注释:$1\le n\le 50$,$1\le 限制\le 1000$. 想法:正负背包.在背包的之后更新用两行更新,保证每一个$\delta$值都被计入了答案. 最后,附上丑陋的代码... ... #include <iostream> #include <cstdio> #include <