一本通 1267:【例9.11】01背包问题(详细代码+严谨思路+清晰图片)

news2024/9/21 18:54:30

经典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/134759.html

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

相关文章

Git Stash、Git Merge、Git Rebase、Git Revert

GIT 日常使用总结git stashgit mergegit rebase将多个commit合并成一个commitgit revert撤销修改撤销commit 但是不撤销add 的内容撤销addGIT Rebase 补充说明&#xff1a;git stash git stash&#xff1a;将修改后的代码存储到本地的一个栈结构&#xff0c;将工作区和暂存区恢…

37-Vue之ECharts高级-交互API

交互API前言全局ECharts对象echartsInstance对象前言 本篇来学习下ECharts中交互API的使用 全局ECharts对象 全局 echarts 对象是引入 echarts.js 文件之后就可以直接使用的 init &#xff1a;初始化ECharts实例对象&#xff0c;使用主题 registerTheme&#xff1a;注册主题…

Avatar和虚拟场景如何影响用户VR社交行为

对于VR社交来讲&#xff0c;虚拟场景&#xff08;社交环境&#xff09;、Avatar&#xff08;虚拟化身&#xff09;是两个重要的元素&#xff0c;一个代表了人们在VR中互动的空间&#xff0c;而另一个则代表他们在这个空间中所扮演的角色。现阶段&#xff0c;Avatar有多种形态&a…

已解决import tensorflow.contrib.layers as layers导包错误

已解决W tensorflow/stream_executor/platform/default/dso_loader.cc:64] Could not load dynamic library ‘cudart64_110.dll’; dlerror: cudart64_110.dll not found I tensorflow/stream_executor/cuda/cudart_stub.cc:29] Ignore above cudart dlerror if you do not ha…

opencv-python常用函数解析及参数介绍(八)——轮廓与轮廓特征

轮廓与轮廓特征前言1.获取轮廓通过膨胀与腐蚀获得轮廓通过梯度获取轮廓通过边缘检测获取轮廓2.寻找轮廓参数及作用对比3.轮廓特征前言 在前面的文章中我们已经学会了使用膨胀与腐蚀、使用梯度、使用边缘检测的方式获得图像的轮廓&#xff0c;那么在获得轮廓后我们可以对图像进…

​赛分科技冲刺科创板上市:拟募资8亿元,复星、高瓴为股东​

近日&#xff0c;苏州赛分科技股份有限公司&#xff08;下称“赛分科技”&#xff09;在上海证券交易所递交招股书&#xff0c;准备在科创板上市。本次冲刺上市&#xff0c;赛分科技计划募资8亿元&#xff0c;将用于20万升/年生物医药分离纯化用辅料、研发中心建设项目&#xf…

《收获,不止Oracle》读书笔记一

当今时代 技术人员&#xff0c;真正的差距其实在意识 1.忽略了知识的重点 20%的知识&#xff0c;解决80%的问题 2.从未考虑知识落地 知识要落地&#xff0c; 要思考应用的场合。 学习任何技术都是一样的&#xff0c;没有思考过你所学的某项技术有什么用&#xff0c;没有想…

P1827 [USACO3.4] 美国血统 American Heritage

题目描述 农夫约翰非常认真地对待他的奶牛们的血统。然而他不是一个真正优秀的记帐员。他把他的奶牛 们的家谱作成二叉树&#xff0c;并且把二叉树以更线性的“树的中序遍历”和“树的前序遍历”的符号加以记录而 不是用图形的方法。 你的任务是在被给予奶牛家谱的“树中序遍历…

计算机网络 | 湖科大教书匠

一、因特网概述 1、网络、互联网和因特网 网络是由若干结点和连接这些结点的链路组成 多个网络还可以通过路由器互联起来&#xff0c;这样就构成了一个覆盖范围更大的网络&#xff0c;互联网 因此&#xff0c;互联网是网络的网络&#xff08;Network of Networks&#xff0…

hadoop+ranger+kerberos页面权限配置(四)

一、原理介绍 hdfs 指令测试&#xff1a;hdfs dfs -mkdir /ranger 原理&#xff1a;根据路径进行文件夹操作赋权。一旦指定文件夹权限&#xff0c;则该用户可以操作该文件夹及该文件夹底下的子文件夹。 yarn 指令测试&#xff1a;hadoop jar /home/hadoop/module/hadoop-3.2.2…

跨平台数据库管理器DbGate

本文软件由网友 zxc 推荐&#xff1b;隔了很久才开始写&#xff0c;又隔了很久才想起来发 &#x1f602; 什么是 DbGate &#xff1f; DbGate 是跨平台的数据库管理器。支持 MySQL、PostgreSQL、SQL Server、MongoDB、SQLite 等的数据库管理器。能够在 Windows、Linux、Mac 下运…

Z函数(扩展KMP)

1,定义 z函数存储字符串s(长度n&#xff0c;下标从0开始&#xff09;与其所有后缀s[i,n-1](0<i<n-1)的最大公共前缀LCP的值&#xff08;一般默认z[0]0,有时是n) 2,思路 叫他扩展KMP是有原因的&#xff0c;因为思想相近&#xff0c;我们求取z[i]&#xff0c;尝试利用前…

20230102单独编译原厂RK3588开发板的开发板rk3588-evb1-lp4-v10的Android12的内核

20230102单独编译原厂RK3588开发板的开发板rk3588-evb1-lp4-v10的Android12的内核 2023/1/2 20:52 《RK3588_Android12_SDK_Developer_Guide_CN.pdf》 原厂的开发板rk3588-evb1-lp4-v10单独编译内核的方式&#xff1a; cd kernel-5.10 export PATH../prebuilts/clang/host/linu…

redis的常见命令

Redis 所有的 key&#xff08;键&#xff09;都是字符串。在谈基础数据结构时&#xff0c;我们讨论的是存储值的数据类型&#xff0c;主要包括常见的 5 种数据类型&#xff0c;分别是&#xff1a;String、List、Set、Zset、Hash 数据结构介绍 Redis 是一个 key-value 的数据库…

Java基础漏洞(一)

最近在复习一些Java基础&#xff0c;填补自己的知识漏洞。 1.转义字符 (1)\t代表的是制表符&#xff0c;\n代表的是空格&#xff0c;\r则代表的是回车 public class Main{public static void main(String[] args) {System.out.println("年龄\t性别\t身高\n18\t男\t183&…

《小猫猫大课堂》4——数组,操作符,常见关键字

更新不易&#xff0c;麻烦多多点赞&#xff0c;欢迎你的提问&#xff0c;感谢你的转发&#xff0c; 最后的最后&#xff0c;关注我&#xff0c;关注我&#xff0c;关注我&#xff0c;你会看到更多有趣的博客哦&#xff01;&#xff01;&#xff01; 喵喵喵&#xff0c;你对我…

十三、网络编程、UDP、TCP协议

JMM(了解) JMM就是Java内存模型(java memory model)。因为在不同的硬件生产商和不同的操作系统下&#xff0c;内存的访问有一定的差异&#xff0c;所以会造成相同的代码运行在不同的系统上会出现各种问题。所以java内存模型(JMM)屏蔽掉各种硬件和操作系统的内存访问差异&#…

python 办公自动后,第一天:创建excel写入数据

1&#xff0c;python第三方模块&#xff1a;xlwt写入excel文件 #pycharm 中安装pip install xlwt #xlwr 用户写入文件模块 #pip install xlwt # pip list 查看安装的模块 # pip install import xlwt#创建excelwb xlwt.Workbook()# 选择工作簿sh wb.add_sheet(第一个sheet页…

LVGL学习笔记11 - 按钮矩阵Button Matrix

目录 1. 构造矩阵 2. Parts 2.1 LV_PART_MAIN 2.2 LV_PART_ITEMS 3. 样式 3.1 按钮大小 3.2 间距 3.3 控制按钮 3.4 控制map 3.5 Check唯一性 4. 事件 4.1 LV_EVENT_VALUE_CHANGED 4.2 LV_EVENT_LONG_PRESSED 4.3 LV_EVENT_DRAW_PART_BEGIN 按钮矩阵是多个按钮的组…

臻图信息搭建土壤墒情监测应用平台,推进现代农业信息化发展

“十四五”期间&#xff0c;国家高度重视土壤生态环境监测等问题&#xff0c;先后出台了一系列规范性文件&#xff0c;为我国土壤防治领域建立了一套标准、导则、指南和管理等解决对策&#xff0c;使我国土壤修复法律法规和标准化建设呈现出系列化和系统化趋势&#xff0c;有效…