小明的背包——01背包问题

经典版

题目链接:1.小明的背包1 - 蓝桥云课 (lanqiao.cn)

01背包问题中,每种物品只有两种状态,即拿或不拿。设状态dp[i][j]=max(dp[i-1][j],dp[i-1][j-w]+v);如果不拿物品i,那么最大价值就是dp[i-1][j],如果拿了就是从体积j-v转移过来,体积会变大w,价值增加v,最后输出dp[N][V]。

package lanqiao;import java.util.Scanner;/*** 2024/3/13* 背包容量为V,商场一共有N件物品,第i件物品的体积为wi,价值为vi* 求不超过体积的情况下所获得的最大价值为多少*/
public class lanqiao1174_小明的背包1 {public static void main(String[] args) {Scanner scan=new Scanner(System.in);int N=scan.nextInt();//物品个数int V=scan.nextInt();//背包容量int[] w=new int[N];//物品体积int[] v=new int[N];//物品价值for (int i=0;i<N;i++){//输入体积和价值w[i]=scan.nextInt();v[i]=scan.nextInt();}int[][] dp=new int[N+1][V+1];for (int i=1;i<=N;i++){for (int j=1;j<=V;j++){dp[i][j]=dp[i-1][j];if (j>=w[i-1]) {dp[i][j] = Math.max(dp[i][j], dp[i - 1][j - w[i - 1]] + v[i - 1]);}}}System.out.println("最大价值为:"+dp[N][V]);}
}
5 20
1 6
2 5
3 8
5 15
3 3
最大价值为:37进程已结束,退出代码为 0

升阶版

01背包的优化

        首先有dp[i][j]=dp[i-1][j],相当于将dp[i-1]复制给dp[i],然后dp[i][j]=max(dp[i-1][j],dp[i-1][j-w]+v),每次下标都是从小转移到大,由此可以将第一维度优化掉,直接设置一个一维数组,每次更新都从后往前更新,即变为:dp[j]=max(dp[j],dp[j-w]+v),dp[j]表示此时物品总重量为j的情况下的最大价值

题目链接:1.背包与魔法 - 蓝桥云课 (lanqiao.cn)

设状态dp[i][j]表示物品总重量为i,且使用了j次魔法的情况下的最大值。

对于每个物品有三种选择:不选、选但不使用魔法、选且使用魔法

dp[j][0] = Math.max(dp[j][0], dp[j - w][0] + v);
dp[j][1] = Math.max(dp[j - w - K][0] + v * 2, dp[j][1]);

其中,dp[j][1]==dp[j][0];

最后输出

Math.max(dp[M][0], dp[M][1])
package lanqiao;import java.util.Scanner;/*** 2024/3/13* 小蓝有N件物品,其中第i件重量是Wi,价值是Vi。他有一个背包,最大承重是M* 求最多能装总价值多少的wupin* 其中,小蓝可以使用一个魔法,仅一次,将一件物品的重量增加K,同时价值翻倍,当然也可以不使用魔法*/
public class lanqiao2223_背包与魔法 {public static void main(String[] args) {Scanner scan = new Scanner(System.in);int N = scan.nextInt();//物品数量int M = scan.nextInt();//背包体积int K = scan.nextInt();//魔法增重int[] w = new int[N];int[] v = new int[N];for (int i = 0; i < N; i++) {w[i] = scan.nextInt();v[i] = scan.nextInt();}int[][] dp = new int[M + 1][2];//定义一个二维数组,一个表示未用魔法的,一个表示使用魔法的,dp[ ][0]   dp[ ][1]for (int i = 1; i <= N; i++) {for (int j = M; j >= 0; j--) {if (j >= w[i - 1]) {dp[j][0] = Math.max(dp[j][0], dp[j - w[i - 1]][0] + v[i - 1]);//未使用魔法的情况dp[j][1] = Math.max(dp[j][1], dp[j - w[i - 1]][1] + v[i - 1]);//通过将为使用魔法的数值复制存储,方便进行下面使用魔法情况的运算}if (j >= w[i - 1] + K) {//考虑使用魔法情况(上述将同一个结果分别存储在不同维度,也是为了此处计算不影响结果)dp[j][1] = Math.max(dp[j - w[i - 1] - K][0] + v[i - 1] * 2, dp[j][1]);}}}System.out.println("最大价值为:" + Math.max(dp[M][0], dp[M][1]));//比较使用魔法和未使用魔法的情况,输出较大的结果}
}
3 10 3
5 10
4 9
3 8
最大价值为:26进程已结束,退出代码为 0

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/537477.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于YOLOv8深度学习的野外火焰烟雾检测系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标检测

《博主简介》 小伙伴们好&#xff0c;我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源&#xff0c;可关注公-仲-hao:【阿旭算法与机器学习】&#xff0c;共同学习交流~ &#x1f44d;感谢小伙伴们点赞、关注&#xff01; 《------往期经典推…

【深度学习】YOLOv9继续训练——断点训练方法

YOLOv9继续训练主要分为两个情况&#xff1a; 其一、训练过程中意外中断&#xff0c;未完成训练预期的epoch数量&#xff1b; 其二、训练完了&#xff0c;但是未收敛&#xff0c;在这个基础上&#xff0c;还想用这个权重、学习率等参数继续训练多一些轮次 一、训练过程中意外…

闯关升级游戏特点,闯关小程序游戏开发

闯关升级类游戏一直以来都备受玩家青睐&#xff0c;其独特的游戏性和吸引力让人们乐此不疲。这类游戏以挑战性关卡和角色成长为核心&#xff0c;让玩家在不断的冒险中获得成就感与乐趣。让我们一起深入探讨这类游戏的特点&#xff0c;以及为何它们如此受欢迎。 挑战性关卡设计…

从零开始利用MATLAB进行FPGA设计(一):建立脉冲检测模型的Simulink模型2

目录 1.模块的总体结构 1.1从工作空间导入输入信号 1.2FIR滤波器 2.Subsystem 3.MATLAB Function 文章灵感来源于MATLAB官方免费教程&#xff1a;HDL Coder Self-Guided Tutorial 考虑到MATLAB官网的英文看着慢&#xff0c;再加上视频讲解老印浓浓的咖喱味&#xff0c;我…

通过日志恢复sql server数据库

在SQL Server中&#xff0c;通过日志恢复数据库是一个精细的过程&#xff0c;主要用于在数据库出现错误、数据丢失或需要回滚到特定时间点时恢复数据。以下是一般步骤概述&#xff1a; 设置恢复模式&#xff1a; 首先&#xff0c;数据库必须配置为“完整恢复模式”或“大容量…

用户数据的FLASH存储与应用(FPGA架构)

该系列为神经网络硬件加速器应用中涉及的模块接口部分&#xff0c;随手记录&#xff0c;以免时间久了遗忘。 一 背景 我们知道&#xff0c;在FPGA做神经网络应用加速时&#xff0c;涉及到权重参数的存储和加载。通常在推理过程中&#xff0c;会将权重参数存储在外部DDR或片上S…

【数据结构】双向链表及LRU缓存的实现

目录 前言 1. 在原有的自定义链表类 Linked 的基础上&#xff0c;添加新的 “节点添加”方法 addNode(Node node) 测试用例 测试结果 2. 在自定义链表类的基础上&#xff0c;使用双重循环“强力” 判断两个节点是否发生相交 测试用例 测试结果 3. 在自定义链表类的基础上…

DBeaver 生成的DDL没有字段注释

场景&#xff0c;需要拷贝几个表。但是因为一些原因无法使用navicat DBeaver生成的DDL语句又没有字段注释 如图&#xff1a; 可以通过以下SQL解决 select * from user_col_comments where table_name 表名 AND owner库名 效果如下&#xff1a; select concat(comment on …

程序调试工具gdb

1.由于在编写程序的过程中&#xff0c;通常会触发计算机无法识别的逻辑错误&#xff0c;导致程序运行的最终结果不尽人意。 &#xff08;1&#xff09;在【Linux】系统下利用【gdb】调试工具进行段错误排查&#xff1a; 步骤&#xff1a;1.根据给定链接设置系统允许生成core文件…

Prompt提示工程上手指南:基础原理及实践(二)-Prompt主流策略

前言 上篇文章将Prompt提示工程大体概念和具体工作流程阐述清楚了&#xff0c;我们知道Prompt工程是指人们向生成性人工智能&#xff08;AI&#xff09;服务输入提示以生成文本或图像的过程中&#xff0c;对这些提示进行精炼的过程。生成人工智能是一个根据人类和机器产生的数…

在线编辑字体工具,支持对字体查看编码以及编辑

公司一个沉寂多年的项目需要进行二开&#xff0c;前面的开发的同学已经离开&#xff0c;对于项目情况了解较少&#xff0c;开发的时候发现缺失很多小图标&#xff0c;但是对原来有那些图标也不太了解 目标 1、知晓字体包里的旧的图标是什么样子的&#xff1f;2、在旧字体包中导…

科技成果鉴定测试如何进行?第三方检测机构进行鉴定测试的好处

科技成果鉴定测试&#xff0c;作为科技领域中一项重要的质量检验手段&#xff0c;具有广泛的应用范围。旨在为科技成果的研发者和使用者提供客观、科学、权威的鉴定结果&#xff0c;从而评估科技成果的技术水平和市场竞争力。   科技成果鉴定测试是对科技成果进行系统、全面的…