0-1背包的动态规划问题

无非就是放与不放的问题,能放10kg的背包,我要考虑放第i个物品,把要放第i-1个物品时候的从0~10kg的最优情况都算出来,不放的话就还是用i-1时候0~10kg对应的价值,放的话,这个东西xkg,放了之后包里还剩10-xkg,那么就是 10-xkg时候得最优值dp[i-1][10-x]再加上这个包得价值。比较放与不放两个价值哪个大,谁大存谁!!!

#include <bits/stdc++.h>
#include <iostream>
#include <algorithm>
using namespace std;
#define Max 10000
int n,m;
int v[Max],w[Max];
int dp[Max][Max];
//n数量,m背包最大承受质量,价值v[i],重量w[i]
//knapsack:小背包
//dp[i][j]表示第i个包在最大重量为j的情况下的价值最优值。
//两种情况:
//第i个不放:dp[i][j]=dp[i-1][j] 比如第五个不放 那么此时dp[5][j]等于第四个背包时候的最优值即dp(4,j);
//第i个放:dp(i,j)=dp(i-1,j-w[i])+w[i] 等于{上一个包,最大为j放了w[i],还剩j-w[i]}此时的value,还要加上v[i]
int Knapsack(int n,int m,int v[],int w[])
{
    for(int i=1;i<=n;i++)
    {
        for(int j=0;j<=m;j++)
        {
            dp[i][j]=dp[i-1][j];//默认不放
            if(j>=w[i])
                dp[i][j]= max(dp[i][j],dp[i-1][j-w[i]]+v[i]);
        }
    }
    int maxValue=0;
    for(int i=1;i<=m;i++)
        maxValue=max(maxValue,dp[n-1][i]);
    return maxValue;
}
int main()
{

    cin>>n>>m;
    for(int i=1;i<=n;i++)
        cin>>w[i]>>v[i];
    int maxValue=Knapsack(n,m,v,w);
    for(int i=1;i<=n;i++)
    {
        for(int j=0;j<=m;j++)
        {
            cout<<dp[i][j]<<" ";
            if(j==m)
                cout<<endl;
        }
    }//输出dp数组,方便理解
    cout<< maxValue<<endl;
    return 0;
}

输入

4 5
1 2
2 4
3 4
4 5

输出

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值