BZOJ-2748: [HAOI2012]音量调节 (傻逼背包DP)
生活随笔
收集整理的這篇文章主要介紹了
BZOJ-2748: [HAOI2012]音量调节 (傻逼背包DP)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
2748: [HAOI2012]音量調節
Time Limit:?3 Sec??Memory Limit:?128 MBSubmit:?2246??Solved:?1413
[Submit][Status][Discuss]
Description
一個吉他手準備參加一場演出。他不喜歡在演出時始終使用同一個音量,所以他決定每一首歌之前他都要改變一次音量。在演出開始之前,他已經做好了一個列表,里面寫著在每首歌開始之前他想要改變的音量是多少。每一次改變音量,他可以選擇調高也可以調低。
音量用一個整數描述。輸入文件中給定整數beginLevel,代表吉他剛開始的音量,以及整數maxLevel,代表吉他的最大音量。音量不能小于0也不能大于maxLevel。輸入文件中還給定了n個整數c1,c2,c3…..cn,表示在第i首歌開始之前吉他手想要改變的音量是多少。
吉他手想以最大的音量演奏最后一首歌,你的任務是找到這個最大音量是多少。
Input
第一行依次為三個整數:n, beginLevel, maxlevel。
第二行依次為n個整數:c1,c2,c3…..cn。
Output
輸出演奏最后一首歌的最大音量。如果吉他手無法避免音量低于0或者高于maxLevel,輸出-1。
Sample Input
3 5 105 3 7
Sample Output
10HINT
?
1<=N<=50,1<=Ci<=Maxlevel 1<=maxlevel<=10000<=beginlevel<=maxlevel
?
Source
這tm是那年省選的簽到題叭……這明明是pj的難度哇……
laj一開始裝逼想用滾動數組,wa了無數次后發現每次滾動的時候都會受到上上次轉移的影響 _(:зゝ∠)_ 下次還是要少裝逼 _(:зゝ∠)_
1 #include "bits/stdc++.h" 2 using namespace std; 3 typedef long long LL; 4 const int MAX=1005; 5 int n,m,v,a[55],f[55][MAX]; 6 int main(){ 7 freopen ("sound.in","r",stdin);freopen ("sound.out","w",stdout); 8 int i,j; 9 scanf("%d%d%d",&n,&m,&v); 10 for (i=1;i<=n;i++) scanf("%d",a+i); 11 f[0][m]=1; 12 for (i=1;i<=n;i++){ 13 for (j=a[i];j<=v;j++) f[i][j]|=f[i-1][j-a[i]]; 14 for (j=0;j<=v-a[i];j++) f[i][j]|=f[i-1][j+a[i]]; 15 } 16 for (i=v;i>=0;i--) if (f[n][i]) return printf("%d",i),0; 17 puts("-1"); 18 return 0; 19 }?
轉載于:https://www.cnblogs.com/keximeiruguo/p/7764654.html
總結
以上是生活随笔為你收集整理的BZOJ-2748: [HAOI2012]音量调节 (傻逼背包DP)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 深度学习小技巧(二):如何保存和恢复sc
- 下一篇: nagios全攻略(一)----准备阶段