用js实现动态规划解决背包问题

动态规划的原理:

移至到该同学的博文中,讲解的声动易懂 https://www.jianshu.com/p/a66d5ce49df5

现在主要是用js来实现动态规划

function bb(v, w, total) {
      var maxValue = [];//用来存储所有的最优值的二维数组
      //i行表示物品种类,j列表示容量,v是价值,w是容量,total是总容量限制
      //表中的每一个值,都是最优值
      //每次都从小容量开始计算,逐步增加到大容量
      for (var i = 0; i < w.length; i++) {
        var row = [];
        for (var j = 0; j <= total; j++) {
          //第一行,只有一个物品可以选择,所以,只要该物品的容量小于该列限定的容量,
          //都可以放进去,并且为当前的最优值
          if (i == 0) {
            if (w[i] <= j) {
              row[j] = v[i];
            } else {
              row[j] = 0;
            }
          } else {
            //从第二行开始,有第二种物品可以放进来
            if (w[i] <= j && (v[i] + maxValue[i-1][j - w[i]] > maxValue[i - 1][j])) {
              //如果第二行的物品的容量小于规定容量,并且还有剩余容量,那么从之前的最优解里面取出剩余容量的最大价值
              //两者相加为当前的最优解,如果当前的最优解,是大于该容量下的上一行存储的价值,则存储该值,否则继续沿用上一行的最优解
              row[j] = v[i] + maxValue[i-1][j - w[i]] || 0;
            } else {
              //该物品容量超过,则沿用上一行的最优解
              row[j] = maxValue[i - 1][j];
            }
          }
        }
        maxValue.push(row);
      }
      console.info(maxValue);
    }
    var v = [4, 5, 6];
    var w = [3, 4, 5];
    bb(v, w, 10);

 

转载于:https://www.cnblogs.com/panyujun/p/10682713.html

JS的01背包问题动态规划算法可以通过以下步骤来实现: 1. 创建一个二维数组dp,用来保存背包容量为i时能够取得的最大价值。 2. 初始化dp数组第一行和第一列为0,表示背包容量为0时或者没有物品可选时,最大价值都为0。 3. 遍历物品列表,对于每一个物品,分为两种情况: a. 物品的重量大于当前背包容量,无法放入背包,所以最大价值与上一个物品相同。 b. 物品的重量小于等于当前背包容量,可以选择放入或者不放入背包。选择放入背包时,最大价值为放入该物品后的剩余容量的最大价值与该物品价值的和;选择不放入背包时,最大价值与上一个物品相同。取这两种情况的最大值作为当前背包容量下的最大价值。 4. 遍历完所有物品后,dp数组的最后一个元素即为背包容量为总容量时的最大价值。 这样,我们就可以通过动态规划的方式解决JS的01背包问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [详解动态规划01背包问题--JavaScript实现](https://blog.csdn.net/weixin_33964094/article/details/88021485)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [JS基于贪心算法解决背包问题示例](https://download.csdn.net/download/weixin_38743602/12961313)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值