Submission #890126

#TimeUsernameProblemLanguageResultExecution timeMemory
890126khohocKnapsack (NOI18_knapsack)C++14
100 / 100
95 ms1876 KiB
#include <algorithm>
#include <iostream>
#include <vector>
using namespace std;
int S, N, V, W, K;
vector<pair<int, int>> A[2001];
long long dp[2001], answer;
int main() {
  cin >> S >> N;
  for (int i = 0; i < N; i++) {
    cin >> V >> W >> K;
    A[W].push_back(make_pair(V, K));
  }
  for (int i = 1; i <= S; i++) {
    sort(A[i].begin(), A[i].end(), greater<pair<int, int>>());
    int index = 0;
    for (int j = 0; j < S / i; j++) {
      if (index >= A[i].size())
        break;
      for (int k = S; k >= i; k--) {
        dp[k] = max(dp[k], dp[k - i] + A[i][index].first);
        answer = max(answer, dp[k]);
      }
      A[i][index].second--;
      if (A[i][index].second == 0)
        index++;
    }
  }
  cout << answer << "\n";
  return 0;
}

Compilation message (stderr)

knapsack.cpp: In function 'int main()':
knapsack.cpp:18:17: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<int, int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   18 |       if (index >= A[i].size())
      |           ~~~~~~^~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...