Java数据结构与算法(完全背包)

前言:

完全背包问题是背包问题的一个变种,与0/1背包问题不同,在完全背包问题中,每种物品可以被选取多次。问题描述如下:

给定 n 件物品,每件物品有一个重量 wi和一个价值 vi,以及一个背包,它能够承载的最大重量为 W。我们需要确定应该将哪些物品放入背包,以使得背包内物品的总价值最大。

背包问题分类:

解题思路:

动态规划是解决完全背包问题的常用方法。我们可以通过修改0/1背包问题的动态规划方法来实现。

核心思想: 构建一个一维数组 dp[j],其中 j 表示当前背包容量。dp[j] 表示容量为 j 的背包中可以获得的最大价值。

状态转移方程:

  • 如果选择第 i件物品:dp[j] = max(dp[j], dp[j - wi] + vi)

实现代码

java 复制代码
public class CompleteKnapsack {
    public static int completeKnapsack(int W, int[] weights, int[] values, int n) {
        int[] dp = new int[W + 1];

        for (int i = 0; i < n; i++) {
            for (int j = weights[i]; j <= W; j++) {
                dp[j] = Math.max(dp[j], dp[j - weights[i]] + values[i]);
            }
        }
        return dp[W];
    }

    public static void main(String[] args) {
        int W = 50; // 背包容量
        int[] weights = {10, 20, 30}; // 物品重量
        int[] values = {60, 100, 120}; // 物品价值
        int n = values.length;

        System.out.println("最大价值: " + completeKnapsack(W, weights, values, n));
    }
}

QA1:0/1背包和完全背包dp设计的差异作用?

dpi的作用就是用于区分一个物品能否重复放置,具体获取的值可以输出打印细细体会。

相关推荐
Evand J4 分钟前
【论文复现】MATLAB例程,存在测距误差的WSN无锚点分布式自定位,《WSN中存在测距误差的无锚点分布式自定位方法》
开发语言·分布式·matlab·定位·导航·wsn
techdashen22 分钟前
kTLS 进入 rustls 组织:把 TLS 的数据面交给内核
开发语言·php
Lhappy嘻嘻38 分钟前
Java 并发编程(六)|并发进阶高频:CAS、锁升级
java·开发语言
techdashen40 分钟前
Arborium:把 tree-sitter 语法高亮打包成 Rust 文档生态的基础设施
开发语言·后端·rust
要开心吖ZSH1 小时前
MVCC 进阶:快照读 vs 当前读、幻读与 Next-Key Lock
java·数据库·sql·mysql·mvcc
京韵养生记1 小时前
【无标题】
java·服务器·前端
会周易的程序员1 小时前
microLog 后端开发指南
开发语言·c++·物联网·设计模式·日志·iot·aiot
小强库计算机毕业设计1 小时前
源码分享Spring Boot + Vue3 的校园社团管理系统
java·spring boot·后端·计算机毕业设计
Esaka_Forever1 小时前
Python 完整内存管理机制详解
开发语言·python·spring
星空露珠1 小时前
迷你世界UGc3.0脚本Wiki[剧情动画模块管理接口 Timeline]
开发语言·数据结构·算法·游戏·lua