美文网首页
刷题—01背包问题手动分析过程

刷题—01背包问题手动分析过程

作者: DuBetter | 来源:发表于2022-06-04 17:33 被阅读0次

手动模拟走了一遍01背包问题,等有空了(看心情)再板书一下。


WechatIMG43.jpeg
WechatIMG44.jpeg

代码(java)

/**
 * Desc: 0-1背包问题
 */
public class BagProblem01 {

    public static void main(String[] args) {

        int[] weight = {1, 3, 4};
        int[] value = {15, 20, 30};
        int bagWeight = 4;

        System.out.println(bagPro01(weight, value, bagWeight));
    }


    /**
     *
     * @param weight 数组,weight[i] 表示第i个物品的重量
     * @param value 数组, value[i] 表示第i个物品的价值
     * @param w 背包的容量(重量)
     * @return 装满背包的最大价值和
     */
    public static int bagPro01(int[] weight, int[] value, int w) {

        // 1定义dp数组,并初始化
        int n = weight.length;
        int[][] dp = new int[n][w + 1]; // 表示从n件物品中选出若干件,使得容量为w的背包的价值和最大【关键点】

        // 初始化第一列,即背包容量为0
        for (int i = 0; i < n; i++) {
            // 对于背包容量为0的情况,啥也放不下,初始化为0,这一步其实可以忽略,数组初始化本身就是0。
            dp[i][0] = 0;
        }

        // 初始化第一行, 即只选第一个物品
        for (int j = 0; j <= w; j++) {
            if (j < weight[0]) { // 背包容量小于第一个物品的重量
                dp[0][j] = 0;
            } else {
                dp[0][j] = value[0];
            }
        }

        // 迭代

        for (int i = 1; i < n; i++) {
            for (int j = 0; j <= w; j++) {
                if (j < weight[i]) {
                    // 表明只装i都装不下
                    dp[i][j] = dp[i - 1][j];
                } else {
                    dp[i][j] = Math.max(dp[i - 1][j], dp[i - 1][j - weight[i]] + value[i]);
                }
            }
        }

        // 打印出来看看dp数组
        for (int i = 0; i < n; i++) {
            for (int j = 0; j <= w; j++) {
                System.out.print(dp[i][j] + " ");
            }
            System.out.println();
        }

        return dp[n - 1][w];
    }
}

相关文章

  • 刷题—01背包问题手动分析过程

    手动模拟走了一遍01背包问题,等有空了(看心情)再板书一下。 代码(java)

  • Poj 1014 Dividing

    昨天刷了一个最简单的 01 背包,正好趁热打铁,多搞几个背包的题。题目位于 Dividing,copy 如下: 大...

  • 01背包

    01背包的问题很早就想写了,但是因为一些意外的事情耽搁了下来今天补习一下01背包问题的计算过程。首先,01背包的问...

  • 动态规划-背包问题

    01背包问题 详解:01背包问题详解链接

  • [leetcode刷题笔记]动态规划之背包问题

    当然拿到问题后,需要做到以下几个步骤:1.分析是否为背包问题。2.是三种背包问题中的哪一种。3.是0-1背包问题还...

  • 背包问题1(01背包)

    N件物品,没见有重量Wi,价值Vi;选其中几件放入容量为M的背包中,求价值的最值。——经典背包问题背包问题分三类:...

  • 01背包问题

    动态规划算法一般用来求解最优化问题,当问题有很多可行解,而题目要求寻找这些解当中的“最大值”/“最小值”时,通常可...

  • 01背包问题

    题目描述:给定 n 个物品和一个容量为 W 的背包,物品 i 的重量是 wi,其价值为 vi 。应该如何选择装入背...

  • 01背包问题

    有n个重量和价值分别为wi,vi的物品。从这些物体中挑选出总重量不超过W的物品,求所有方案中价值总和的最大值。 1...

  • 01背包问题

    A - Bone Collector Many years ago , in Teddy’s hometown t...

网友评论

      本文标题:刷题—01背包问题手动分析过程

      本文链接:https://www.haomeiwen.com/subject/zwtlmrtx.html