mltang

博客园 首页 新随笔 联系 订阅 管理
  64 随笔 :: 1 文章 :: 0 评论 :: 13467 阅读
复制代码
#include <bits/stdc++.h>
using namespace std;
vector<int> path;
const int maxn = 37;
short dp[maxn][maxn][maxn][maxn][maxn];
bool tp[maxn][maxn][maxn][maxn][maxn];
int P,C,A,M;
int p[maxn],c[maxn],a[maxn],m[maxn],g[maxn];
int main()
{
    int n;
    scanf("%d",&n);
    for(int i=1;i<= n; ++i)
        scanf("%d%d%d%d%d",p+i,c+i,a+i,m+i,g+i);
    scanf("%d%d%d%d",&P,&C,&A,&M);
    for(int i = 1; i<=n; ++i)
    {
        for(int ip = P; ip>=p[i]; --ip)
            for(int ic = C; ic >= c[i]; --ic)
                for(int ia = A; ia >= a[i]; --ia)
                    for(int im = M; im >= m[i]; --im)
                    {
                        dp[i][ip][ic][ia][im] = dp[i-1][ip][ic][ia][im];
                        if(dp[i][ip][ic][ia][im] < dp[i-1][ip-p[i]][ic-c[i]][ia-a[i]][im-m[i]]+g[i])
                        {
                            dp[i][ip][ic][ia][im] = dp[i-1][ip-p[i]][ic-c[i]][ia-a[i]][im-m[i]]+g[i];
                            tp[i][ip][ic][ia][im] = true;
                        }
                    }
    }
    int ans = 0;
    //cout << dp[1][1][0][2][1] << endl;
    //cout << dp[n][P][C][A][M] << endl;
    for(int i = n; i>=1; --i)
    {
        if(tp[i][P][C][A][M] == true)
        {
            P-=p[i];
            C-=c[i];
            A-=a[i];
            M-=m[i];
            ans ++;
            path.push_back(i-1);
        }
    }
    cout << ans << endl;
    for(int i = path.size()-1; i>=1; --i)
        cout << path[i] << " ";
    cout << path[0] << endl;
}
复制代码

01 背包+路径输出

基本没什么好解释的

posted on   mltang  阅读(119)  评论(0编辑  收藏  举报
点击右上角即可分享
微信分享提示