背包问题讲解和示例

       在面试和笔试的时候,我们经常会遇到经典的背包问题,大多数都是01背包和完全背包的思想,因此我们有必要来了解一下常见的背包问题,本文的讲解主要基于参考博客与Leetcode对应习题来进行的。

        背包问题主要分为01背包、多重背包和完全背包,此节我们只讲01背包和完全背包;下面我们给出了背包问题详细讲解的参考博客,并总结出结论、对应习题和参考代码。


 01背包问题

背包问题:0-1背包、完全背包和多重背包 - fengzw - 博客园

        01背包的状态转换方程:f[i,j] = max ( f[i-1,j-Wi]+Pi(j>=Wi),f[i-1,j] )

        0-1背包问题是指每一种物品都只有一件,可以选择放或者不放。现在假设有n件物品,背包承重为m。

        对于这种问题,我们可以采用一个二维数组去解决:f[i][j],其中i代表加入背包的是前i件物品,j表示背包的承重,f[i][j]表示当前状态下能放进背包里面的物品的最大总价值。那么,f[n][m]就是我们的最终结果了。

        采用动态规划,必须要知道初始状态和状态转移方程。初始状态很容易就能知道,那么状态转移方程如何求呢?对于一件物品,我们有放进或者不放进背包两种选择:

  (1)假如我们放进背包,则f[i][j] = f[i - 1][j - weight[i]] + value[i],这里的f[i - 1][j - weight[i]] + value[i]应该这么理解:在没放这件物品之前的状态值加上要放进去这件物品的价值。而对于f[i - 1][j - weight[i]]这部分,i - 1很容易理解,关键是 j - weight[i]这里,我们要明白:要把这件物品放进背包,就得在背包里面预留这一部分空间。

  (2)假如我们不放进背包,f[i][j] = f[i - 1][j],这个很容易理解。

    因此,我们的状态转移方程就是:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值