【ETOJ P1024】无穷背包 题解(动态规划+完全背包)

2024-02-10 10:28

本文主要是介绍【ETOJ P1024】无穷背包 题解(动态规划+完全背包),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

e e e 的背包容量为 m m m,现在商店里有 n n n 种商品。由于在梦境中,他可以零元购,商店里的每种商品都有无穷件,每件商品有一个价值 w i w_i wi 和体积 v i v_i vi

问小 e e e 最多可以带走多少价值的商品?

输入

第一行两个整数表示 m , n m, n m,n。( 1 ≤ m ≤ 1 0 5 , 1 ≤ n ≤ 500 1 ≤ m ≤ 10^5, 1 ≤ n ≤ 500 1m105,1n500

接下来 n n n 行,每行两个整数表示 w i , v i w_i, v_i wi,vi。( 1 ≤ w i ≤ 1 0 9 , 1 ≤ v i ≤ m 1 ≤ w_i ≤ 10^9, 1 ≤ v_i ≤ m 1wi109,1vim

输出

一行一个整数表示答案。

样例输入

10 3
2 1
5 3
10 4

样例输出

24

提示

解释:拿两件物品3,再拿两件物品1,得到价值最大为24。


思路

首先,读取背包容量 m m m 和商品种类数 n n n,然后读取每种商品的价值和体积。动态规划数组 dp 被定义来存储在给定背包容量下可以获得的最大价值。dp[j] 表示背包容量为 j j j 时的最大价值。

然后,对于每种商品 i i i,从其体积 v i v_i vi m m m 遍历背包的容量 j j j。如果选择了商品 i i i,背包的容量会减少 v i v_i vi,但是可以增加 w i w_i wi 的价值。因此,dp[j] 被更新为 dp[j]dp[j - v[i]] + w[i] 中的较大值,这表示在背包容量为 j j j 时,选择或者不选择商品 i i i 的两种情况下的最大价值。

最后,输出 dp[m],即在背包容量为 m m m 时,可以获得的最大价值。


AC代码

#include <algorithm>
#include <iostream>
#define ll long long
#define AUTHOR "HEX9CF"
using namespace std;const int N = 1e6 + 7;int m, n;
int w[N], v[N];
ll dp[N];int main() {cin >> m >> n;for (int i = 1; i <= n; i++) {cin >> w[i] >> v[i];}for (int i = 1; i <= n; i++) {for (int j = v[i]; j <= m; j++) {dp[j] = max(dp[j], dp[j - v[i]] + w[i]);}}cout << dp[m] << endl;return 0;
}

这篇关于【ETOJ P1024】无穷背包 题解(动态规划+完全背包)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/696850

相关文章

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

从入门到精通详解Python虚拟环境完全指南

《从入门到精通详解Python虚拟环境完全指南》Python虚拟环境是一个独立的Python运行环境,它允许你为不同的项目创建隔离的Python环境,下面小编就来和大家详细介绍一下吧... 目录什么是python虚拟环境一、使用venv创建和管理虚拟环境1.1 创建虚拟环境1.2 激活虚拟环境1.3 验证虚

从基础到高级详解Python数值格式化输出的完全指南

《从基础到高级详解Python数值格式化输出的完全指南》在数据分析、金融计算和科学报告领域,数值格式化是提升可读性和专业性的关键技术,本文将深入解析Python中数值格式化输出的相关方法,感兴趣的小伙... 目录引言:数值格式化的核心价值一、基础格式化方法1.1 三种核心格式化方式对比1.2 基础格式化示例

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

浅谈MySQL的容量规划

《浅谈MySQL的容量规划》进行MySQL的容量规划是确保数据库能够在当前和未来的负载下顺利运行的重要步骤,容量规划包括评估当前资源使用情况、预测未来增长、调整配置和硬件资源等,感兴趣的可以了解一下... 目录一、评估当前资源使用情况1.1 磁盘空间使用1.2 内存使用1.3 CPU使用1.4 网络带宽二、

go动态限制并发数量的实现示例

《go动态限制并发数量的实现示例》本文主要介绍了Go并发控制方法,通过带缓冲通道和第三方库实现并发数量限制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录带有缓冲大小的通道使用第三方库其他控制并发的方法因为go从语言层面支持并发,所以面试百分百会问到

一文详解SpringBoot中控制器的动态注册与卸载

《一文详解SpringBoot中控制器的动态注册与卸载》在项目开发中,通过动态注册和卸载控制器功能,可以根据业务场景和项目需要实现功能的动态增加、删除,提高系统的灵活性和可扩展性,下面我们就来看看Sp... 目录项目结构1. 创建 Spring Boot 启动类2. 创建一个测试控制器3. 创建动态控制器注

springboot如何通过http动态操作xxl-job任务

《springboot如何通过http动态操作xxl-job任务》:本文主要介绍springboot如何通过http动态操作xxl-job任务的问题,具有很好的参考价值,希望对大家有所帮助,如有错... 目录springboot通过http动态操作xxl-job任务一、maven依赖二、配置文件三、xxl-