算法修炼之筑基篇——筑基一层(解决01背包问题)

news2024/11/26 12:16:44

✨博主:命运之光

专栏:算法修炼之练气篇​​​​​

博主的其他文章:点击进入博主的主页

前言:学习了算法修炼之练气篇想必各位蒟蒻们的基础已经非常的扎实了,下来我们进阶到算法修炼之筑基篇的学习。筑基期和练气期难度可谓是天差地别,懂得都懂,题目难度相比起练气期的题目难度提升很多,所以要是各位蒟蒻小伙伴们看不懂筑基期的题目可以在练气期多积累积累,练气期的题目也会不断更新,大家一定要把基础打牢固了再来看筑基期的题目哈,这样子也可以提高大家的学习效率,一举两得,加油(●'◡'●)🎉🎉

 

 

目录

✨经典的01背包问题

🍓小明的背包1 

🍓解题代码

🍓dp数组打表如下:

​编辑 ✨经典01背包问题的解题思路

✨01背包的递推公式(重要需要记忆)

✨01背包的递推公式优化为一维数组(重要需要记忆)


✨经典的01背包问题

让我们先看一道经典的01背包问题

🍓小明的背包1 

 

🍓解题代码

#include<bits/stdc++.h>
using namespace std;
int wi[105],vi[105],dp[1005][1005];
int main()
{
	int n,v;//n为行数,v为背包的大小
	cin>>n>>v;//传入n,v的值
	for(int i=1;i<=n;i++)
	{
		cin>>wi[i]>>vi[i];//传入重量和价值 
	}
	//写dp数组
	int i,j;
	for(i=1;i<=n;i++)
	{
		for(j=1;j<=v;j++)
		{
			if(j<wi[i])
			{
				dp[i][j]=dp[i-1][j];//如果重量没j大的话,就直接继承dp数组上一列的最优解,直接dp[i-1][j]即可 
			}
			else
			{
				//若是比j大则进行比较,这道题标准的01背包问题,直接套用01背包推出的公式即可 
				dp[i][j]=max(dp[i-1][j],dp[i-1][j-wi[i]]+vi[i]);	
			} 
		}
	 } 
	cout<<dp[n][v];
	return 0;
}

🍓dp数组打表如下:

 ✨经典01背包问题的解题思路

在C/C++中,可以使用动态规划来解决01背包问题。动态规划是一种常用的解决优化问题的算法思想,它通过将问题分解为子问题,并利用子问题的解来构建更大规模的问题的解。

以下是使用动态规划解决01背包问题的基本步骤:

  1. 定义问题:我们需要确定背包的容量和物品的重量和价值。假设背包的容量为C,有n个物品,每个物品的重量为w[i],价值为v[i]。

  2. 创建一个二维数组dp[n+1][C+1],其中dp[i][j]表示在前i个物品中,背包容量为j时的最大价值。

  3. 初始化边界条件:当物品数量为0或背包容量为0时,最大价值都为0,即dp[i][0] = dp[0][j] = 0。

  4. 递推关系:对于每个物品i,我们有两种选择:放入背包或不放入背包。如果选择放入背包,那么当前的最大价值为dp[i][j] = dp[i-1][j-w[i]] + v[i];如果选择不放入背包,那么当前的最大价值为dp[i][j] = dp[i-1][j]。我们选择两者中的较大值作为dp[i][j]的值。

  5. 递推计算:使用循环遍历物品和背包容量,根据递推关系计算dp[i][j]的值。

  6. 返回结果:dp[n][C]即为问题的解,表示在前n个物品中,背包容量为C时的最大价值。

🍓下面是一个示例代码,演示了如何使用动态规划解决01背包问题:

#include <iostream>
using namespace std;

int knapsack(int C, int weights[], int values[], int n) {
    int dp[n + 1][C + 1];

    // 初始化边界条件
    for (int i = 0; i <= n; i++)
        dp[i][0] = 0;
    for (int j = 0; j <= C; j++)
        dp[0][j] = 0;

    // 计算最大价值
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= C; j++) {
            if (weights[i - 1] <= j) {
                dp[i][j] = max(values[i - 1] + dp[i - 1][j - weights[i - 1]], dp[i - 1][j]);
            } else {
                dp[i][j] = dp[i - 1][j];
            }
        }
    }

    return dp[n][C];
}

int main() {
    int C = 10;  // 背包容量
    int weights[] = {2, 3, 4, 5};  // 物品重量
    int values[] = {3, 4, 5, 6};   // 物品价值
    int n = sizeof(weights) / sizeof(weights[0]);  // 物品数量

    int max_value = knapsack(C, weights, values, n);
    cout << "最大价值:" << max_value << endl;

    return 0;
}

在这个示例中,背包的容量C为10,有4个物品,重量分别为2、3、4和5,价值分别为3、4、5和6。运行程序将输出最大价值为10,即当背包容量为10时,从这些物品中选择可以得到的最大价值。你可以根据实际情况修改输入的背包容量、物品重量和价值,来解决不同的01背包问题。

✨01背包的递推公式(重要需要记忆)

dp[i][j] = max(dp[i-1][j], dp[i-1][j-w[i]] + v[i])

其中,dp[i][j]表示在前i个物品中,背包容量为j时的最大价值,w[i]表示第i个物品的重量,v[i]表示第i个物品的价值。

递推公式的含义是,在考虑第i个物品时,我们有两种选择:

  1. 不选择第i个物品,即仅考虑前i-1个物品,此时的最大价值为dp[i-1][j]
  2. 选择第i个物品,那么背包的容量就会减少,变为j-w[i],此时的最大价值为dp[i-1][j-w[i]] + v[i],即在考虑前i-1个物品、背包容量为j-w[i]时的最大价值,再加上第i个物品的价值v[i]。

我们选择上述两种选择中的较大值作为dp[i][j]的值,即表示在考虑前i个物品、背包容量为j时的最大价值。

需要注意的是,上述递推公式中的dp数组是一个二维数组,大小为(n+1) x (C+1),其中n表示物品的数量,C表示背包的容量。初始化时,需要设置边界条件,即dp[0][j] = dp[i][0] = 0,表示当物品数量为0或背包容量为0时的最大价值为0。

✨01背包的递推公式优化为一维数组(重要需要记忆)

dp[j] = max(dp[j], dp[j-w[i]] + v[i])

其中,dp[j]表示背包容量为j时的最大价值,w[i]表示第i个物品的重量,v[i]表示第i个物品的价值。

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

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

相关文章

raise AssertionError(“Torch not compiled with CUDA enabled“)

1、运行代码可知&#xff0c;当前cuda不可用。 import torch print(torch.cuda.is_available()) # False 2、打开power shell or cmd&#xff0c;输入nvidia-smi命令&#xff0c;检查当前英伟达显卡信息。 可知当前驱动版本512.78&#xff0c;支持的cuda最高版本为11.6&…

时间序列教程 六、深度学习与时间序列分析结合

一、深度学习方法 与传统的时间序列预测模型相比,神经网络有以下几个好处: 1、自动学习如何将趋势、季节性和自相关等系列特征纳入预测。 2、能够捕捉非常复杂的模式。 3、可以同时建模许多相关的系列,而不是单独处理每个系列。 但是神经网络有一些劣势: 1、模型的构建可能…

PyCharm开发工具的安装与使用

PyCharm集成开发工具(IDE),是当下全球python开发者&#xff0c;使用最频繁的工具软件。绝大多数的python程序&#xff0c;都是在PyCharm工具内完成的开发。 1.先进行下载并安装它 下载官网地址&#xff1a;https://www.jetbrains.com/pycharm/download/#sectionwindows 宝子…

SpringBoot自定义拦截器实现权限过滤功能(基于责任链模式)

前段时间写过一篇关于自定义拦截器实现权限过滤的文章&#xff0c;当时是用了自定义mybatis拦截器实现的&#xff1a;SpringBoot自定义Mybatis拦截器实现扩展功能(比如数据权限控制)。最近学习设计模式发现可以用责任链模式实现权限过滤&#xff0c;因此本篇采用责任链模式设计…

Docker(概述、安装、配置、镜像操作)

一、docker是什么&#xff1f; docker是一种go语言开发的应用容器引擎&#xff0c;运行容器里的应用。docker是用来管理容器和镜像的一种工具。 容器引擎&#xff1a;docker、rocket、podman、containerd 容器与虚拟机的区别 容器&#xff1a;所有容器共享宿主机内核。使用…

【手撕Spring源码】AOP

文章目录 AOP 实现之 ajc 编译器AOP 实现之 agent 类加载AOP 实现之 proxyJDK代理CGLIB代理JDK动态代理进阶CGLIB代理进阶MethodProxy JDK 和 CGLIB 在 Spring 中的统一切点匹配从 Aspect 到 Advisor通知转换调用链执行静态通知调用动态通知调用 AOP 底层实现方式之一是代理&am…

Java/Compose Desktop项目中进行python调用

写在前面 开发compose desktop项目爬网站时遇到验证码处理不方便需要借助python庞大的处理能力&#xff0c;这时需要再项目中调用python去执行获取结果&#xff0c;这里记录一下使用过程。 本次开发记录基于&#xff1a;python 3.9&#xff0c;compose 1.3 java17 工具&#x…

2年测试我迷茫了,软件测试大佬都会哪些技能?我的测试进阶之路...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 Python自动化测试&…

【MCS-51单片机汇编语言】期末复习总结④——求定时器初值(题型四)

文章目录 重要公式T~机器~ 12 / ∫~晶振~(2^n^ - X) * T~机器~ T~定时~ 工作方式寄存器TMOD常考题型例题1题解方式0方式1 关于定时器的常考题目为已知晶振 ∫ 、定时时间&#xff0c;求定时器初值。 重要公式 T机器 12 / ∫晶振 (2n - X) * T机器 T定时 其中n为定时器位数…

线性代数2:矩阵(1)

目录 矩阵&#xff1a; 矩阵的定义&#xff1a; 0矩阵 方阵 同型矩阵&#xff1a; 矩阵相等的判定条件 矩阵的三则运算&#xff1a; 乘法的适用条件 矩阵与常数的乘法&#xff1a; 矩阵的乘法&#xff1a; 矩阵的乘法法则&#xff1a; Note1&#xff1a; Note2&…

【数据库】表数据delete了,表文件大小不变

背景 在本周的时候&#xff0c;接到了短信数据空间报警短信&#xff0c;提示的是磁盘空间占用80以上&#xff0c;而这个数据库总体的存储量一共100G&#xff0c;商量之后决定在不升配置的前提下&#xff0c;删除一些不需要的数据表。比如针对A表删除1000W数据。但是和DBA沟通后…

FAST-LIO2论文阅读

目录 迭代扩展卡尔曼滤波增量式kd-tree&#xff08;ikd-tree&#xff09;增量式维护示意图ikd-tree基本结构与构建ikd-tree的增量更新&#xff08;Incremental Updates&#xff09;逐点插入与地图下采样使用lazy labels的盒式删除属性更新 ikd-tree重平衡平衡准则重建及并行重建…

SMTP简单邮件传输协议(C/C++ 发送电子邮件)

SMTP是用于通过Internet发送电子邮件的协议。电子邮件客户端&#xff08;如Microsoft Outlook或macOS Mail应用程序&#xff09;使用SMTP连接到邮件服务器并发送电子邮件。邮件服务器还使用SMTP将邮件从一个邮件服务器交换到另一个。它不用于从服务器下载电子邮件&#xff1b;相…

jmeter安装及使用

jmeter安装及使用 一、说明二、安装2.1 目录结构 三、使用3.1 运行jmeter3.2 设置语言3.3 设置线程组3.3.1 设置压测请求3.3.2 设置汇总报告3.3.3 设置结果树 3.4 开始压测 四、导出执行报告4.1 保存配置4.2 执行命令4.3 生成报告常见问题 一、说明 最近需要对项目接口进行压测…

vue简单实现一个类似微信左右滑动更多功能

1、需求背景 产品需要在购物车加一个左右滑动更多的功能&#xff0c;由于是PC端&#xff0c;大致扫描了下使用的UI库&#xff0c;貌似没有单独提供此类组件&#xff0c;反正有时间&#xff0c;就自己造一个轮子试试 2、先看效果 大致有一个橡皮筋的效果&#xff0c;可能没那…

分布式锁方案学习

很久没有写文章了&#xff0c;前些天的面试被问到了分布式锁的解决方案&#xff0c;回答的比较简单&#xff0c;只知道Redis&#xff0c;Mysql&#xff0c;Zookeeper能够作为分布式锁应用&#xff0c;今天就来详细的学习一下这三种分布式锁的设计思想及原理。 能够来看这篇文章…

05WEB系统的通信原理图

WEB系统的通信原理 名称作用URL统一资源定位符, 例如:http://www.baidu.com域名在https://www.baidu.com/这个网址中www.baidu.com 是一个域名IP地址计算机在网络当中的一个身份证号, 在同一个网络当中IP地址是唯一的, 有了IP地址两台计算机直接才能建立连接通信端口号一个计算…

如何让你的汇报更有说服力?数据监控是关键!

第5讲中玩过一个扫雷游戏&#xff0c;目标是排除计划中的“延期地雷”&#xff0c;但是&#xff0c;总有些“雷”防不胜防。我们在做计划的时候&#xff0c;明明已经想得非常周全了&#xff0c;可是&#xff0c;真正开工几天之后才发现&#xff0c;很多事情并没有那么简单。 1…

4-1 活动安排问题

1.什么是贪心算法 我的理解&#xff1a; 贪心算法是一种常用的问题求解方法&#xff0c;它在每个步骤上都选择当前看起来最优的解&#xff0c;而不考虑整体的最优解。简单来说&#xff0c;贪心算法采取局部最优的决策&#xff0c;希望通过每个局部最优解的选择&#xff0c;最终…

网络安全面试题大全(整理版)500+面试题附答案详解,最全面详细,看完稳了

前言 随着国家政策的扶持&#xff0c;网络安全行业也越来越为大众所熟知&#xff0c;想要进入到网络安全行业的人也越来越多。 为了拿到心仪的Offer之外&#xff0c;除了学好网络安全知识以外&#xff0c;还要应对好企业的面试。 作为一个安全老鸟&#xff0c;工作这么多年&…