一本通 1267:【例9.11】01背包问题(详细代码)

news2024/11/15 10:42:58

经典01背包问题

这里给你3种方法


目录

DFS

思路:

代码:

DFS+记忆化

思路:

代码:

动态规划

思路:

代码:


DFS

时间复杂度 :O(2^n)

思路:

DFS求出所有选法,再用ans记录价格最大值

由于此题数据量较小(其实2^30=1073741824,这种做法是过不了的,是题目数据比较水^_^)

代码:

//【例9.11】01背包问题
#include <iostream>
#include <algorithm>

using namespace std;

const int N = 35;

int n, m, ans;//n 容量    m 物品
int w[N], v[N]; //w 第i件物品的重量(代价)   v 第i件物品的价值

//idx 物品编号   resw 背包剩余容量   sumv 当前决策下的总价值
void dfs(int idx, int resw, int sumv) {
	if (idx == n + 1) {
		ans = max(ans, sumv);
		return ;
	}

	//不选
	dfs(idx + 1, resw, sumv);
	//选
	if (resw >= w[idx])
		dfs(idx + 1, resw - w[idx], sumv + v[idx]);
}

int main() {
	cin >> m >> n;

	for (int i = 1; i <= n; i ++)
		cin >> w[i] >> v[i];

	dfs(1, m, 0);

	cout << ans;
	return 0;
}
/*
【输入样例】
10 4
2 1
3 3
4 5
7 9
【输出样例】
12
*/

如果在考试遇到这种01背包题目DFS是肯定拿不了满分的


DFS+记忆化

时间复杂度:O(nm)

针对上一个做法 纯·DFS 有可能会超时的情况我们推出了加上记忆化的版本

思路:

我们分析一下为什么 纯·DFS 做法会超时

我们用一个小样例自己推一下

 先不管答案是什么,我们发现dfs(1, 5)出现了多次

如果样例再大一点就会有很多重复子问题

重复子问题 ?想到什么了?对了,用记忆化存储状态!

只要在上一种方法的代码加上一个二维dp数组存储状态就能起到优化时间复杂度的作用

dp[i][j] 代表 用前i件物品来装容量为j的背包所能得到的最大价值

代码:

//【例9.11】01背包问题
#include <iostream>
#include <algorithm>

using namespace std;

const int N = 35, M = 205;

int n, m;//n 容量    m 物品
int w[N], v[N]; //w 第i件物品的重量(代价)   v 第i件物品的价值

/*
idx 物品编号   resw 背包剩余容量
	如果
	第i件物品不选
		dfs(i, j) = dfs(i - 1, j)
	第i件物品选
		dfs(i, j) = dfs(i - 1, j - w[i]) + v[i]
*/
int dp[N][M];
int dfs(int idx, int resw) {
	//用前i件物品来装容量为j的背包所能得到的最大价值
	if (!idx)
		return 0;
	if (dp[idx][resw] != -1)
		return dp[idx][resw];

	//不选
	int maxn = dfs(idx - 1, resw);
	//选
	if (resw >= w[idx])
		maxn = max(maxn, dfs(idx - 1, resw - w[idx]) + v[idx]);

	return dp[idx][resw] = maxn;
}

int main() {
	cin >> m >> n;

	for (int i = 1; i <= n; i ++)
		cin >> w[i] >> v[i];

	memset(dp, -1, sizeof dp);

	cout << dfs(n, m);
	return 0;
}
/*
【输入样例】
10 4
2 1
3 3
4 5
7 9
【输出样例】
12
*/

动态规划

时间复杂度:O(nm)

思路:

其实也就是把 DFS+记忆化 改成递推形式,在上一种方法的代码里也已经透露了状态转移方程

第i件物品不选
	dp[i, j] = dp[i - 1, j]
第i件物品选
	dp[i, j] = dp[i - 1, j - w[i]] + v[i]

代码:

//【例9.11】01背包问题   O(nm)
#include <iostream>
#include <algorithm>

using namespace std;

const int N = 35, M = 205;

int n, m;//n 容量    m 物品
int w[N], v[N]; //w 第i件物品的重量(代价)   v 第i件物品的价值
int dp[N][M];

int main() {
	cin >> m >> n;

	for (int i = 1; i <= n; i ++)
		cin >> w[i] >> v[i];

	/*
	dp[i, j] 用前i件物品来装容量为j的背包所能得到的最大价值
	第i件物品不选
		dp[i, j] = dp[i - 1, j]
	第i件物品选
		dp[i, j] = dp[i - 1, j - w[i]] + v[i]
	*/
	for (int i = 1; i <= n; i ++) {
		for (int j = 0; j <= m; j ++) {
			dp[i][j] = dp[i - 1][j]; //不选
			if (j >= w[i]) //可选
				dp[i][j] = max(dp[i][j], dp[i - 1][j - w[i]] + v[i]);
		}
	}
	cout << dp[n][m];
	return 0;
}
/*
【输入样例】
10 4
2 1
3 3
4 5
7 9
【输出样例】
12
*/

代码可以拿走,请把赞留下

原题链接:信息学奥赛一本通(C++版)在线评测系统 (ssoier.cn)

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Maven 之 依赖管理

目录 1、依赖传递 小案例&#xff1a; 2、可选依赖 3、 排除依赖 4、可选依赖和排除依赖的区别 我们开发一个工程需要用到大量得jar包&#xff0c;而这些jar 包就是我们所说得依赖&#xff0c;一个项目可以配置多个依赖。 1、依赖传递 我们来看一下今天用来演示的工程。…

Linux性能学习(1.4):CPU_如何查看CPU上下文切换参数

文章目录1 系统总体上下文参数2 进程的上下文切换参数3 其它参考资料&#xff1a;vmstat&#xff1a;一个标准的报告虚拟内存统计工具 在前面大致了解了上下文切换的相关知识&#xff0c;那么如何在系统中查看上下文切换相关的参数&#xff1f; 1 系统总体上下文参数 使用vm…

人工势场法路径规划算法(APF)

本文主要对人工势场法路径规划算法进行介绍&#xff0c;主要涉及人工势场法的简介、引力和斥力模型及其推导过程、人工势场法的缺陷及改进思路、人工势场法的Python与MATLAB开源源码等方面 一、人工势场法简介 人工势场法是由Khatib于1985年在论文《Real-Time Obstacle Avoidan…

WPF使用触发器需要注意优先级问题

总目录 文章目录总目录前言一、问题开始二、问题说明三、问题订正总结前言 WPF使用触发器需要注意优先级问题 一、问题开始 现在有个需求&#xff1a; 初始状态&#xff08;未选中&#xff09;的时候&#xff0c;CheckBox的Content 为 “乒乓球”&#xff0c;然后选中之后&am…

python机器学习《基于逻辑回归的预测分类》

前言&#xff1a; 本文所有代码均在阿里天池实验室运行&#xff0c;本机的jupyter notebook也可运行。除此之外&#xff0c;还需要导入numpy,matplotlib,sklearn,seaborn包。每期文章前面都会有环境搭建说明。文中的讲解知识点均是按照从上往下讲解&#xff0c;将一些平常未接触…

⼯⼚⽅法模式

⼯⼚⽅法模式 ⼯⼚⽅法模式&#xff0c;属于创建者模式中的一种&#xff0c;这类模式提供创建对象的机制&#xff0c; 能够提升已有代码的灵活性和可复⽤性。 创建者模式包括&#xff1a;⼯⼚⽅法、抽象⼯⼚、⽣成器、原型、单例&#xff0c;这5类。 1.⼯⼚⽅法模式介绍 ⼯⼚…

LaoCat带你认识容器与镜像(二【一章】)

系列二章&#xff0c;祝大家新的一年事事顺心&#xff0c;想要的一定都实现。 本章内容 使用Docker镜像。 本文实操全部基于Ubuntu 20.04 一、使用Docker镜像 镜像&#xff08;image&#xff09;是Docker三大核心概念中最重要的&#xff0c;Docker运行容器前需要本地存在对应得…

在wsl下开发T113的主线linux(5)-构建ubi文件系统

接下来是构建文件系统&#xff0c;这里使用最新的buildroothttps://buildroot.org/download.htmlhttps://buildroot.org/download.html tar xf buildroot-2022.11.tar.gz cd buildroot-2022.11 make menuconfig 配置目标指令集类型 配置外部自定义编译器 配置生成文件系统类型…

数据结构和算法--算法与数据结构的概述、简单排序

目录 算法 算法概述 算法复杂度 数据结构 数据结构的概述 物理结构 逻辑结构 简单排序 1.选择排序 1.1算法描述 1.2算法实现 2冒泡排序 2.1算法描述 2.2算法实现 3插入排序 3.1算法描述 3.2算法实现 三种算法的比较 算法 算法概述 算法是一系列程序指令&am…

回溯算法题型

目录 一组合总和 二组合总和 三子集 四全排列 五解数独 一组合总和 题目描述&#xff1a; 找出所有相加之和为 n 的 k 个数的组合&#xff0c;且满足下列条件&#xff1a; 只使用数字1到9每个数字 最多使用一次 返回 所有可能的有效组合的列表 。该列表不能包含相同的组…

ArcGIS基础:提取道路中心线

本实验为对道路路面数据进行中心线提取 以路边两侧边界为准&#xff0c;运用等分的办法实现道路中心线提取&#xff0c;原始数据如下所示&#xff08;来源于网络&#xff09;。 道路顶端有一些圆弧段的部分&#xff0c;需要把其去除。 首先要做的是面转线操作&#xff0c;如下…

HashMap解读

1.简介 HashMap &#xff0c;是一种散列表&#xff0c;用于存储 key-value 键值对的数据结构&#xff0c;一般翻译为“哈希表”&#xff0c;提供平均时间复杂度为 O(1) 的、基于 key 级别的 get/put 等操作。 2.哈希表结构 哈希表结构为数组&#xff0c;链表和红黑树。如图 …

已解决+ FullyQualifiedErrorId : UnauthorizedAccess

已解决无法加载文件 E:\day_01\Scripts\activate.ps1&#xff0c;因为在此系统上禁止运行脚本。有关详细信息&#xff0c;请参阅 https:/go.microsoft.com/fwlink/?LinkID135170 中的about_Execution_Policies。 CategoryInfo: SecurityError: &#xff08;:&#xff09; [ ]…

Spring Bean的配置详解

目录 1.bean基础配置 例如&#xff1a;配置UserDaolmpl由Spring容器负责管理 2.Spring开发中主要是对Bean的配置&#xff0c; Bean的常用配置一览如下&#xff1a; 3.bean的别名配置 4.bean作用范围配置 5.bean的实例化 6.bean生命周期 7.Spring的get方法 8.Bean的延迟加载…

57. 数据增广 / 图像增广 代码实现

1. 图像增广 在对常用图像增广方法的探索时&#xff0c;我们将使用下面这个尺寸为400 x 500的图像作为示例。 从github上把img下载下来后&#xff0c;放到同一目录下&#xff1a; d2l.set_figsize() img d2l.Image.open(./img/cat1.jpg) d2l.plt.imshow(img);大多数图像增广…

数字通信系统和模拟通信系统的简单介绍

关于数字和模拟&#xff0c;比较形象的一个对比如下图所示。 模拟系统就好比传统的钟表&#xff0c;秒钟一直在走&#xff0c;也就是连续之意&#xff1b;而数字系统相当于数字表&#xff0c;“ &#xff1a;”的闪烁相当于二进制的 0 和 1&#xff0c;有离散之意。 模拟通信系…

a billion ways to grasp

https://blog.csdn.net/weixin_26752765/article/details/108132661 翻译自 https://darshanhegde.github.io/blog/2020/heuristics-for-robotic-grasping/ 讲述了各种抓取 https://rpal.cse.usf.edu/competition_iros2021/ Grasping is one of the fundamental subtask of a r…

ECCV 2022|DynamicDepth:动态场景下的多帧自监督深度估计

&#x1f3c6;前言&#xff1a;本文别名DynamicDepth (github),如本文的名字所示&#xff0c;本文着重处理的就是动态场景下的多帧自监督深度估计问题。因为MVS在动态场景下会失效&#xff0c;所以在动态区域的多帧深度并不可靠。现在的已有方法例如ManyDepth&#xff0c;利用t…

老王linux面试题汇总

1.统计一个网站的访问量&#xff0c;统计网站访问次数最多的前几名的IP地址。 2.取两个文件的相同和不同行 3.分别创建10个账号&#xff08;user1-user10&#xff09; 5.独立磁盘冗余阵列RAID O,1,5,6,10,01级别区别 5.1磁盘利用率 5.2最少几盘磁盘实现 5.3容错性&#xff0c;…

(十二)大白话对于VARCHAR这种变长字段,在磁盘上到底是如何存储的?

文章目录 1、一行数据在磁盘上存储的时候,包含哪些东西?2、变长字段在磁盘中是怎么存储的?3、存储在磁盘文件里的变长字段,为什么难以读取?4、引入变长字段的长度列表,解决一行数据的读取问题5、引入变长字段长度列表后,如何解决变长字段的读取问题?6、如果有多个变长字…