TakahiroNakamori

TakahiroNakamori

ナカモリタカヒロ

 
 

高橋くんの苦悩

問題

D – 高橋くんの苦悩
プログラミング初級者から上級者まで楽しめる、競技プログラミングコンテストサイト「AtCoder」。オンラインで毎週開催プログラミングコンテストを開催しています。競技…

記録

解法

コード例

#include <bits/stdc++.h>
using namespace std;
#include <atcoder/all>
using namespace atcoder;
using ll = long long;
using P = pair<int, int>;
#define rep(i, n) for(int i = 0; i < (n); ++i)
// using mint = modint998244353;
// using mint = modint1000000007;
// const int mod = 1000000007;
// const ll INF = 1LL << 62;
// const int INF = 1001001001;

int dp[55][55][10010];

int main() {
  int W, N, K;
  cin >> W >> N >> K;

  vector<int> A(N + 1);
  vector<int> B(N + 1);
  rep(i, N) { cin >> A[i] >> B[i]; }

  for(int i = 0; i < 55; ++i) {
    for(int j = 0; j < 55; ++j) {
      for(int k = 0; k < 10010; ++k) {
        dp[i][j][k] = -1;
      }
    }
  }

  dp[0][0][0] = 0;

  for(int i = 0; i < N; ++i) {
    for(int j = 0; j <= K; ++j) {
      for(int k = 0; k <= W; ++k) {
        if(dp[i][j][k] == -1) {
          continue;
        }
        dp[i + 1][j][k] = max(dp[i][j][k], dp[i + 1][j][k]);
        if(j == K) {
          continue;
        }
        if(k + A[i] <= W) {
          dp[i + 1][j + 1][k + A[i]] =
              max(dp[i + 1][j + 1][k + A[i]], dp[i][j][k] + B[i]);
        }
      }
    }
  }

  int ans = 0;
  for(int j = 0; j <= K; ++j) {
    for(int k = 0; k <= W; ++k) {
      ans = max(ans, dp[N][j][k]);
    }
  }
  cout << ans << endl;
  return 0;
}