8.10 动态规划例题---01背包问题之dp(动态规划)解法

2024-02-18 08:58

本文主要是介绍8.10 动态规划例题---01背包问题之dp(动态规划)解法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

分析:从第一行开始从左向右查找

对于物品3,容量4

要该物品:f(3,4) = 物品价值+f(物品3的上一个物品2,容量4-物品重量);

不要该物品:f(3,4) = f(物品3的上一个物品,容量4)

最后取max(要f,不要f)

代码:


import java.util.Arrays;
import java.util.Scanner;public class Main {/* * 思路:(1)计算之前先查询记忆数组rem中是否已存在改记录*                    (1.1)如果存在,直接将该结果返回*                    (1.2)如果不存在,再计算*            	并将计算结果存到rem数组中,再返回结果* 测试记录:
4
5
2 1 3 2
3 2 4 2*/static int n;//物品数static int W;//背包的容量限制static int[] ws;//每个物品的重量static int[] vs;//每个物品的价值static int[][] dp;//动态规划表(记录每个物品在每种容量下的总价值)public static void main(String[] args) {//(1)输入相关数据Scanner sc = new Scanner(System.in);n = sc.nextInt();int W = sc.nextInt();ws = new int[n];vs = new int[n];for(int i=0;i<n;i++) {//输入每个物品重量ws[i]=sc.nextInt();}for(int i=0;i<n;i++) {//输入每个物品价值vs[i]=sc.nextInt();}//(2)初始化dp表dp = new int[n][W+1]; //物品编号0~n-1 、容量编号0~W//初始化第一行(物品0,在容量0~W下的价值)for(int i=0;i<=W;i++) {//i:背包容量if(ws[0]<=i) {//物品0的重量<背包容量i,选择物品0dp[0][i]=vs[0];//记录选择物品0后的价值}else {//容量不足,不选物品0dp[0][i]=0;}}//(3)依次遍历剩余的物品1~n-1for(int i=1;i<n;i++) {//物品ifor(int j=0;j<=W;j++) {//背包容量jint vv=0;//记录当前情况下的最大价值if(ws[i]<=j) {//背包容量足够int v1 = vs[i]+dp[i-1][j-ws[i]];//选择物品i。当前价值 = 物品i的价值 + 上一个物品i-1 在容量j-ws[i]的价值int v2 = dp[i-1][j]; //不选物品i。当前价值=上一个物品i-1在容量j下的价值vv=Math.max(v1, v2);}else {//背包容量不足vv=dp[i-1][j];//即不选物品i}dp[i][j]=vv;}}//(4)最后获取物品n-1,容量W下的最大价值System.out.println(dp[n-1][W]);}
}

这篇关于8.10 动态规划例题---01背包问题之dp(动态规划)解法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

golang实现动态路由的项目实践

《golang实现动态路由的项目实践》本文主要介绍了golang实现动态路由项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习... 目录一、动态路由1.结构体(数据库的定义)2.预加载preload3.添加关联的方法一、动态路由1

IDEA下"File is read-only"可能原因分析及"找不到或无法加载主类"的问题

《IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题》:本文主要介绍IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题,具有很好的参... 目录1.File is read-only”可能原因2.“找不到或无法加载主类”问题的解决总结1.File

idea中project的显示问题及解决

《idea中project的显示问题及解决》:本文主要介绍idea中project的显示问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录idea中project的显示问题清除配置重China编程新生成配置总结idea中project的显示问题新建空的pr

redis在spring boot中异常退出的问题解决方案

《redis在springboot中异常退出的问题解决方案》:本文主要介绍redis在springboot中异常退出的问题解决方案,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴... 目录问题:解决 问题根源️ 解决方案1. 异步处理 + 提前ACK(关键步骤)2. 调整Redis消费者组

Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题

《Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题》:本文主要介绍Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录一、前言二、系统架构检测三、卸载旧版 Go四、下载并安装正确版本五、配置环境变量六、验证安装七、常见

解决Java异常报错:java.nio.channels.UnresolvedAddressException问题

《解决Java异常报错:java.nio.channels.UnresolvedAddressException问题》:本文主要介绍解决Java异常报错:java.nio.channels.Unr... 目录异常含义可能出现的场景1. 错误的 IP 地址格式2. DNS 解析失败3. 未初始化的地址对象解决

springboot+vue项目怎么解决跨域问题详解

《springboot+vue项目怎么解决跨域问题详解》:本文主要介绍springboot+vue项目怎么解决跨域问题的相关资料,包括前端代理、后端全局配置CORS、注解配置和Nginx反向代理,... 目录1. 前端代理(开发环境推荐)2. 后端全局配置 CORS(生产环境推荐)3. 后端注解配置(按接口

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Idea插件MybatisX失效的问题解决

《Idea插件MybatisX失效的问题解决》:本文主要介绍Idea插件MybatisX失效的问题解决,详细的介绍了4种问题的解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录一、重启idea或者卸载重装MyBATis插件(无需多言)二、检查.XML文件与.Java(该文件后缀Idea可能会隐藏

Python Selenium动态渲染页面和抓取的使用指南

《PythonSelenium动态渲染页面和抓取的使用指南》在Web数据采集领域,动态渲染页面已成为现代网站的主流形式,本文将从技术原理,环境配置,核心功能系统讲解Selenium在Python动态... 目录一、Selenium技术架构解析二、环境搭建与基础配置1. 组件安装2. 驱动配置3. 基础操作模