제출 #1264975

#제출 시각아이디문제언어결과실행 시간메모리
1264975marshziinKnapsack (NOI18_knapsack)C++20
100 / 100
86 ms34376 KiB
#include <bits/stdc++.h>
using namespace std;

#define int long long
#define pii pair<int,int>

const long long NEG = (long long)-9e18;

int32_t main() {
    ios_base::sync_with_stdio(false); cin.tie(0);

    int s, n;
    if (!(cin >> s >> n)) return 0;
    map<int, vector<pii>> W;
    for (int i = 0; i < n; ++i) {
        int v, w, k; cin >> v >> w >> k;
        W[w].push_back({v, k});
    }

    int groups = (int)W.size();
    vector<vector<long long>> dp(groups + 1, vector<long long>(s + 1, NEG));
    dp[0][0] = 0;

    int cur = 1;
    for (auto [weight, items] : W) {
        sort(items.begin(), items.end(), greater<pii>());

        dp[cur][0] = dp[cur - 1][0];

        for (int i = 1; i <= s; ++i) {
            dp[cur][i] = dp[cur - 1][i];

            int cnt = 0;
            int sum = weight, pos = 0, cum = 0;
            while (sum <= s && pos < (int)items.size()) {
                if (cnt == items[pos].second) {
                    pos++;
                    cnt = 0;
                    continue;
                }

                cum += items[pos].first;
                if (i >= sum && dp[cur - 1][i - sum] != NEG) {
                    dp[cur][i] = max(dp[cur][i], dp[cur - 1][i - sum] + cum);
                }
                sum += weight;
                cnt++;
            }
        }
        cur++;
    }

    long long res = 0;
    for (int i = 1; i <= s; ++i) res = max(res, dp[cur - 1][i]);
    cout << res << '\n';
    return 0;
}
#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...