背包问题---

一、背包模型

        有一个体积为V的背包,商店有n个物品,每个物品有一个价值v和体积w,每个物品只能被拿一次,问能够装下物品的最大价值。

        这里每一种物品只有两种状态即"拿"或"不拿".

        设状态dp[i][j]表示到第i个物品为止,拿的物品总体积为j的情况下的最大价值。

        并不关心某个物品有没有被拿,只关心当前体积下的最大价值。

        转移方程为: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];

例题---小明的背包1

https://www.lanqiao.cn/problems/1174/learning/

        小明有一个容量为V的背包。这天他去商场购物,商场一共有N件物品,第i件物品的体积为w_{i},价值为v_{i}

        小明想知道在购买的物品总体积不超过V的情况下所能获得的最大价值为多少,请你帮他算算。

输入描述:输入第1行包含两个正整数N,V,表示商场物品的数量和小明的背包容量。

                  第2~N+1行包含2个正整数w,v,表示物品的体积和价值。

1<=N<=10^{2},1<=V<=10^{3},1<=w_{i},v_{i}<=10^{3}

输出描述:输出一行整数表示小明所能获得的最大价值。

示例:5 20

           1 6

           2 5

           3 8

           5 15

           3 3                                                                                          37

import java.util.Scanner;public class Main {public static void main(String[] args) {// TODO Auto-generated method stubScanner scan = new Scanner(System.in);int n = scan.nextInt();// num of thingsint weight = scan.nextInt();// the package weightint v[] = new int[n];// value of thingint w[] = new int[n];// weight of thingint dp[][] = new int[n + 1][weight + 1];for (int i = 0; i < n; i++) {w[i] = scan.nextInt();v[i] = scan.nextInt();}for (int i = 0; i < n + 1; i++) {for (int j = 0; j < weight + 1; j++) {if (i == 0 || j == 0) {dp[i][j] = 0;continue;}if (j < w[i - 1]) {dp[i][j]=dp[i-1][j];}else {dp[i][j]=Math.max(dp[i-1][j], v[i-1]+dp[i-1][j-w[i-1]]);}}}System.out.println(dp[n][weight]);scan.close();}
}

2、01背包的优化

例题---背包与魔法

https://www.lanqiao.cn/problems/2223/learning/

        小蓝面前有N件物品,其中第i件重量是w_{i},价值是

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

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

相关文章

DotNetBar的SlidePanel和metroTilePanel使用笔记

一、前言 界面组件DotNetBar2中的2个控件属性SlidePanel和metroTitlePanel的使用方法&#xff0c;网上相关资源较少&#xff0c;就一些属性的使用学习记录如下&#xff1a; SlideSideDevComponents.DotNetBar.Controls.eSlideSide.Top/Bottom/Right/Left 及 metroTilePanel和m…

nest路由参数

当你需要接受动态数据作为接口请求的一部分时&#xff08;例如&#xff1a;GET请求 /cats/1 获取 id 为 1 的数据&#xff09; 可以在路径中添加路由参数的标记 :参数名 &#xff0c;捕捉该位置的动态值 将Param()装饰器加在函数接收参数的位置中&#xff0c;然后使用 1. 写法…

环形链表2--绝妙的运算

一、要求 给定一个链表的头节点 head &#xff0c;返回链表开始入环的第一个节点。 如果链表无环&#xff0c;则返回 null。 如果链表中有某个节点&#xff0c;可以通过连续跟踪 next 指针再次到达&#xff0c;则链表中存在环。 为了表示给定链表中的环&#xff0c;评测系统…

FPGA高端项目:解码索尼IMX327 MIPI相机+2路视频融合叠加,提供开发板+工程源码+技术支持

目录 1、前言2、相关方案推荐本博主所有FPGA工程项目-->汇总目录我这里已有的 MIPI 编解码方案 3、本 MIPI CSI-RX IP 介绍4、个人 FPGA高端图像处理开发板简介5、详细设计方案设计原理框图IMX327 及其配置MIPI CSI RX图像 ISP 处理HLS多路视频融合叠加图像缓存HDMI输出工程…

Unity 使用 IL2CPP 发布项目

一、为什么用 IL2CPP Unity的IL2CPP&#xff08;Intermediate Language to C&#xff09;是一个编译技术&#xff0c;它将C#代码转换为C代码&#xff0c;然后再编译成平台相关的二进制代码。IL2CPP提供了几个优点&#xff0c;特别是在性能和跨平台部署方面。以下是IL2CPP的一些…

在OKR的管理中,管理者应该如何切实有效的追踪进展,确保其有效落地?

在OKR&#xff08;Objectives and Key Results&#xff0c;目标与关键成果&#xff09;的管理中&#xff0c;管理者对于进展的追踪是确保整个系统有效落地的重要环节。有效的追踪不仅能帮助团队保持对目标的清晰认知&#xff0c;还能及时发现问题&#xff0c;调整策略&#xff…

多线程学习-线程池

目录 1.线程池的作用 2.线程池的实现 3.自定义创建线程池 1.线程池的作用 当我们使用Thread的实现类来创建线程并调用start运行线程时&#xff0c;这个线程只会使用一次并且执行的任务是固定的&#xff0c;等run方法中的代码执行完之后这个线程就会变成垃圾等待被回收掉。如…

Vue2(十三):Vuex环境搭建、Vuex工作原理、几个配置项、多组件共享数据、Vuex模块化

一、Vuex 1.理解 1.概念&#xff1a;专门在Vue中实现集中式状态(数据&#xff09;管理的一个Vue插件&#xff0c;对vue应用中多个组件的共享状态进行集中式的管理&#xff08;读/写&#xff09;&#xff0c;也是一种组件间通信的方式&#xff0c;且适用于任意组件间通信。 2…

对抗样本攻击

对抗样本是指经过特殊设计或调整的输入数据&#xff0c;旨在欺骗人工智能模型&#xff0c;使其产生错误的预测或输出。对抗样本通常是通过对原始输入进行微小但精心计算的改变&#xff0c;使得模型产生意外的结果。这种模糊化的输入可能难以从人类角度甄别&#xff0c;但对机器…

顺序表的应用

文章目录 目录1. 基于动态顺序表实现通讯录项目2.顺序表经典算法2.1 [移除元素](https://leetcode.cn/problems/remove-element/description/)2.2 [合并两个有序数组](https://leetcode.cn/problems/merge-sorted-array/description/) 3. 顺序表的问题及思考 目录 基于动态顺序…

随机森林、AdaBoost 和 XGBoost 三者之间的主要区别

&#x1f349; CSDN 叶庭云&#xff1a;https://yetingyun.blog.csdn.net/ 集成学习是一种强大的机器学习范式&#xff0c;它通过构建并结合多个学习器来提高预测性能。其中&#xff0c;随机森林、AdaBoost 和 XGBoost 是集成学习领域中著名且广泛应用的方法。尽管这些方法共享…

比selenium体验更好的ui自动化测试工具: cypress介绍

话说 Cypress is a next generation front end testing tool built for the modern web. And Cypress can test anything that runs in a browser.Cypress consists of a free, open source, locally installed Test Runner and a Dashboard Service for recording your tests.…