1 条题解

  • 0
    @ 2023-1-3 19:51:30
    #include <bits/stdc++.h>
    using namespace std;
    const int MAXN = 30;
    const int MAXM = 200;
    int n, m;
    int v[MAXN + 5], w[MAXN + 5], p[MAXN + 5];
    int dp[MAXM + 5];
    int main()
    {
        ios::sync_with_stdio(false);
        cin.tie(0);
        cin >> m >> n;
        for (int i = 1; i <= n; i++)
            cin >> v[i] >> w[i] >> p[i];
        for (int i = 1; i <= n; i++)
        {
            if (p[i] == 0)
            {
                for (int j = v[i]; j <= m; j++)
                    dp[j] = max(dp[j],
                                dp[j - v[i]] + w[i]);
            }
            else
            {
                for (int t = 1; t <= p[i]; t++)
                    for (int j = m; j >= v[i]; j--)
                        dp[j] = max(dp[j],
                                    dp[j - v[i]] + w[i]);
            }
        }
        cout << dp[m] << "\n";
        return 0;
    }
    
    • 1

    信息

    ID
    489
    时间
    1000ms
    内存
    128MiB
    难度
    4
    标签
    (无)
    递交数
    20
    已通过
    18
    上传者