蓝桥杯-小明的背包(动态规划-Java)

0/1背包问题介绍

0/1背包问题是经典的动态规划问题,具体描述如下:

解题思路:

  1. 输入数据 首先,程序通过 Scanner 从输入中读取数据:

    n 表示物品的数量。 v 表示背包的最大容量。 接着读取每个物品的重量和价值,保存在二维数组 a 中。

  2. 动态规划数组 dp 初始化 我们定义一个二维数组 dp[i][j],表示在考虑前 i 个物品,且背包容量为 j 时的最大价值。初始化时,所有的 dp[i][j] 值为 0。

  3. 填充动态规划数组 使用两层循环来填充 dp 数组:

外层循环遍历所有物品(从 i = 1 到 i = n)。 内层循环遍历所有背包容量(从 j = 1 到 j = v)。 对于每个物品 i

和背包容量 j,判断当前物品能否放入背包,如果可以放入背包,我们取放入和不放入两种选择的最大值。

  1. 输出结果 最终,dp[n][v] 存储了在考虑所有 n 个物品并且背包容量为 v 时的最大价值。

代码:

java 复制代码
public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);

        int n = sc.nextInt();
        int v = sc.nextInt();
        int[][] a = new int[n + 1][2];
        //题目已知背包的体重为w,有N个物品,每个物品的价值value和重量weight
        for (int i = 0; i < n; i++) {
            a[i][0] = sc.nextInt();
            a[i][1] = sc.nextInt();
        }
        sc.close();

        //dp数组维护的是在考虑前i个物品,且背包容量为j时,能够获得的最大价值
        int[][] dp = new int[n + 1][v + 1];

        //判断前i件物品,在背包容量为j时,情况下选择最大的价值
        for (int i = 1; i <= n; i++) {
            for (int j = 1; j <= v; j++) {
                // a[i][0]wi重量 a[i][1]vi价格
                int wi = a[i-1][0];
                int vi = a[i-1][1];
                //背包容量够的话
                if (j >= vi) {
                    dp[i][j] = Math.max(dp[i - 1][j], vi + dp[i - 1][j - wi]);
                } else {
                    //背包装不下只能跟刚才一样
                    dp[i][j] = dp[i - 1][j];
                }
            }
        }
        System.out.println(dp[n][v]);

    }
相关推荐
hqxstudying2 小时前
Java异常处理
java·开发语言·安全·异常
我命由我123455 小时前
Kotlin 数据容器 - List(List 概述、创建 List、List 核心特性、List 元素访问、List 遍历)
java·开发语言·jvm·windows·java-ee·kotlin·list
武子康7 小时前
Java-80 深入浅出 RPC Dubbo 动态服务降级:从雪崩防护到配置中心秒级生效
java·分布式·后端·spring·微服务·rpc·dubbo
YuTaoShao10 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
源码_V_saaskw10 小时前
JAVA图文短视频交友+自营商城系统源码支持小程序+Android+IOS+H5
java·微信小程序·小程序·uni-app·音视频·交友
超浪的晨10 小时前
Java UDP 通信详解:从基础到实战,彻底掌握无连接网络编程
java·开发语言·后端·学习·个人开发
双力臂40411 小时前
Spring Boot 单元测试进阶:JUnit5 + Mock测试与切片测试实战及覆盖率报告生成
java·spring boot·后端·单元测试
Edingbrugh.南空11 小时前
Aerospike与Redis深度对比:从架构到性能的全方位解析
java·开发语言·spring
QQ_43766431412 小时前
C++11 右值引用 Lambda 表达式
java·开发语言·c++
永卿00112 小时前
设计模式-迭代器模式
java·设计模式·迭代器模式