Submission #1014810

#TimeUsernameProblemLanguageResultExecution timeMemory
1014810KindaGoodGamesKnapsack (NOI18_knapsack)C++14
29 / 100
2 ms432 KiB
#include <bits/stdc++.h>

#define ll long long
//#define int ll
#define pii pair<int, int>
#define tiii tuple<int, int, int>

using namespace std;

int32_t main()
{
    int n, s;
    cin >> s >> n;

    vector<int> value(n), weight(n), capacity(n);

    vector<int> dp(s);

    for (int i = 0; i < n; i++)
    {
        cin >> value[i] >> weight[i] >> capacity[i];
    }

    if(n == 1){
        cout << min(s/weight[0], capacity[0]) * value[0];
        return 0;
    }

    for (int i = 0; i < n; i++)
    {
        for (int j = s; j > 0; j--)
        {
            //dp[j] = max(dp[j],dp[j - 1]);
            if (j < weight[i])
                continue;
            for (int k = 1; k <= capacity[i]; k++)
            {
                if(k*weight[i] > j) break;
                dp[j] = max(dp[j], dp[j - (k*weight[i])] + (k*value[i]));
            }
        }
    }

    int ma = 0;
    for(int i = 0; i <= s; i++){
        ma = max(ma, dp[i]);
    }
    cout << ma;
}
#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...