problem description
最近xhd正在玩一款叫做fate的遊戲,為了得到極品裝備,xhd在不停的殺怪做任務。久而久之xhd開始對殺怪產生的厭惡感,但又不得不通過殺怪來公升完這最後一級。現在的問題是,xhd昇掉最後一級還需n的經驗值,xhd還留有m的忍耐度,每殺乙個怪xhd會得到相應的經驗,並減掉相應的忍耐度。當忍耐度降到0或者0以下時,xhd就不會玩這遊戲。xhd還說了他最多隻殺s只怪。請問他能昇掉這最後一級嗎?
input
輸入資料有多組,對於每組資料第一行輸入n,m,k,s(0 < n,m,k,s < 100)四個正整數。分別表示還需的經驗值,保留的忍耐度,怪的種數和最多的殺怪數。接下來輸入k行資料。每行資料輸入兩個正整數a,b(0 < a,b < 20);分別表示殺掉乙隻這種怪xhd會得到的經驗值和會減掉的忍耐度。(每種怪都有無數個)
output
輸出公升完這級還能保留的最大忍耐度,如果無法公升完這級輸出-1。
sample input
10 10 1 101 110 10 1 9
1 19 10 2 10
1 12 2
sample output
0-11
中文題看著就是順眼~。~ 糾結了半天經驗值和忍耐力哪個是體積,哪個是價值。然後華麗麗的卡到了如何表示殺怪數既然都說了是二維揹包,那麼理應是多了一層for迴圈啊~而且第三層迴圈的變數的值與第一維表示的第幾個物件加進去他倆沒關係!(⊙﹏⊙)b
即 不要自己為是的加l<=k&&l<=i
而最後找忍耐力的最小值時,從小到大遍歷一遍 遇到經驗值大於n的就立即輸出就好了嘛 哪有你想象中還要定義乙個陣列那麼複雜→_→
另:mark一下goto語句的寫法@。@
/********
hdu2159
2015.10.27
15ms 1612k 1022 b
********/
#include #include#include#includeusing namespace std;
int dp[105][105],k,n,m,s,a[105],b[105];
int main()}}
int flag=0;
for(int i=1;i<=m;i++)}}
loop :
if(!flag) printf("-1\n");
}return 0;
}
HDU2159 FATE 二維完全揹包
problem description 最近xhd正在玩一款叫做fate的遊戲,為了得到極品裝備,xhd在不停的殺怪做任務。久而久之xhd開始對殺怪產生的厭惡感,但又不得不通過殺怪來公升完這最後一級。現在的問題是,xhd昇掉最後一級還需n的經驗值,xhd還留有m的忍耐度,每殺乙個怪xhd會得到相應的...
HDU 2159 FATE(二維完全揹包)
中文題目就不用解釋了 就是裸的二維完全揹包 d i j 表示消耗i忍耐殺j個怪最多可獲得的經驗 然後就用完全揹包來做了 二維揹包揹包不過是多了一重迴圈 include include includeusing namespace std const int n 105 int main return...
HDU 2159 FATE 二維完全揹包
problem description 最近xhd正在玩一款叫做fate的遊戲,為了得到極品裝備,xhd在不停的殺怪做任務。久而久之xhd開始對殺怪產生的厭惡感,但又不得不通過殺怪來公升完這最後一級。現在的問題是,xhd昇掉最後一級還需n的經驗值,xhd還留有m的忍耐度,每殺乙個怪xhd會得到相應的...