https://atcoder.jp/contests/abc087/tasks/abc087_b
この問題をdpで解こうとしています。
C++
1#include <bits/stdc++.h> 2using namespace std; 3 4const int INF = 1<<29; 5 6int main(){ 7 int B[3]; 8 for(int i=0;i<3;i++) cin >> B[i]; 9 int X; cin >> X; 10 int dp[6][21000]; 11 int A[3] = {500 , 100 ,50}; 12 for (int i = 0; i < 6; ++i) for (int j = 0; j < 21000; ++j) dp[i][j] = INF; 13 dp[0][0] = 0; // dp[0][0] だけ 0 に 14 15 int count = 0 ; 16 17 for (int i = 0; i < 3; ++i) { 18 for (int j = 0; j <= X; ++j) { 19 if (dp[i][j] < INF) dp[i+1][j] = 0; 20 if (j >= A[i]) { 21 if (dp[i][j-A[i]] < INF) { 22 dp[i+1][j] = min(dp[i+1][j], 1); 23 } 24 if (dp[i+1][j-A[i]] < B[i]) { 25 dp[i+1][j] = min(dp[i+1][j], dp[i+1][j-A[i]] + 1); 26 } 27 } 28 if(dp[3][X] < INF){ 29 count++; 30 dp[3][X] = INF; 31 } 32 } 33 } 34 35 cout << count << endl; 36}
基本的な考え方は https://algo-method.com/tasks/313
を参考にしています。これだと答えが思い通りに出ないのですが、どなたかご教示いただけないでしょうか?
例えば、入力で
5
1
0
150
となっているとき、このようなパターンは存在しないので0のはずが、1を出力してしまいます。
他にも
30
40
50
6000
で213パターンあるのに、1しか出力しないなどです
どういう答えが出るんでしょうか
そして、それがどうなればいいんでしょう。
具体的に説明しましょう
回答2件
あなたの回答
tips
プレビュー