代码随想录 第九章 动态规划part03 01背包问题 一维 416. 分割等和子集

news/2024/9/18 6:34:49/ 标签: 动态规划, 代理模式, 算法

01背包问题 一维

#include <bits/stdc++.h>
using namespace std;
int main(){int n, bagWeight;cin >> n >> bagWeight;std::vector<int> value(n, 0);std::vector<int> weight(n, 0);for (int i = 0; i < n; i++) cin >> weight[i];for (int i = 0; i < n; i++) cin >> value[i];std::vector<int> result(bagWeight + 1, 0);for (int i = weight[0]; i<=bagWeight; i++) result[i] = value[0];for (int i = 1; i < n; i++){for (int j = bagWeight; j >= 0; j--){if (j >= weight[i]) result[j] = max(result[j], result[j - weight[i]] + value[i]);}}cout << result[bagWeight];return 0;
}

一维与二维的区别在于记录最优价值的数组是一维还是二维,从随想录所给的计算思路可以看出,在计算二维数组的过程中,只需要知道上一行的数据即可计算下一行的最优价值,所以完全可以只借助一个一维数组,不断迭代数组的值,求取最终的最优价值。

416. 分割等和子集

class Solution {
public:bool canPartition(vector<int>& nums) {int sum=0;for (int i = 0; i < nums.size(); i++) sum += nums[i];if (sum % 2 != 0) return false;vector<int> value((sum / 2) + 1, 0);for (int i = nums[0]; i < value.size(); i++) value[i] = nums[0];for (int i = 1; i < nums.size(); i++){for (int j = sum / 2; j>=0; j--){if (j >= nums[i]) value[j] = max(value[j], value[j - nums[i]] + nums[i]);}}if (value[sum / 2] != sum / 2) return false;return true;}
};

这题乍一看首先想到的思路就是回溯,不过现在是动态规划了。如果将数字集合看做重量与价值相等的物品集合,如果集合能分为两个和相等的子集,在背包问题中也就意味着在背包最大容量为所有物品重量和的1/2时,最多能装下重量为所有物品和的1/2的物品,因为物品价值与重量相等,所以最优价值不会大于背包容量,但如果最终最优价值低于背包容量,也就代表数字集合无法被分为两个和相等的部分。

代码随想录 第九章 动态规划part03


http://www.ppmy.cn/news/1524827.html

相关文章

mysql性能优化-云服务与数据库即服务(DBaaS)优化

一、云服务与DBaaS概述 1.1 云服务的特性 云服务&#xff08;Cloud Service&#xff09;通过虚拟化技术提供了灵活的计算资源&#xff0c;按需分配且弹性伸缩。相比传统的自建数据中心&#xff0c;云服务具备以下优势&#xff1a; 弹性伸缩&#xff1a;根据业务需求&#xf…

Python发邮箱:如何配置SMTP服务器发邮件?

Python发邮箱基础教程&#xff1f;python如何实现发送邮件功能&#xff1f; 无论是工作中的项目协作&#xff0c;还是生活中的日常交流&#xff0c;电子邮件都能快速传递信息。而使用Python发邮箱&#xff0c;更是让这一过程自动化、高效化。AokSend将详细介绍如何配置SMTP服务…

使用Python和Proxy302代理IP高效采集Bing图片

目录 项目背景一、项目准备环境配置 二、爬虫设计与实现爬虫设计思路目标网站分析数据获取流程 代码实现1. 初始化爬虫类&#xff08;BingImageSpider&#xff09;2. 创建存储文件夹3. 获取图像链接4. 下载图片5. 使用Proxy302代理IP6. 主运行函数 运行截图 三、总结 项目背景 …

上海泗博EtherNet/IP转PROFIBUS DP网关EPS-320IP成都地铁项目应用案例

背景&#xff1a; 地铁&#xff0c;作为城市的活力脉搏&#xff0c;不仅是衔接城市生活的关键纽带&#xff0c;更是现代城市交通体系中不可或缺的核心组成部分。因此&#xff0c;确保地铁的稳定运行对任何一座城市都至关重要。 上海泗博自动化&#xff0c;作为与成都地铁项目合…

Linux从入门到开发实战(C/C++)Day11-aio

什么是aio&#xff1a;异步io&#xff0c;让io过程异步进行&#xff0c;从而提升读写效率 涉及状态切换&#xff1a;用户态、内核态 如何进行aio读操作&#xff1a; 执行异步操作的时候&#xff0c;函数直接返回&#xff08;可以先去做其他事情&#xff09; 同…

机器学习特征-学习篇

一、特征概念 1. 什么是特征 特征是事物可供识别的特殊的征象或标志 在机器学习中&#xff0c;特征是用来描述样本的属性或观测值的变量。它们可以是任何类型的数据&#xff0c;包括数字、文本、图像、音频等。 作用&#xff1a; 特征是训练和评估机器学习模型的基础。好的特…

VScode 的简单使用

目录 1. VScode 的使用 1.1 常用插件 1.2 常用快捷键 1. VScode 的使用 1.1 常用插件 1.2 常用快捷键 也可以“ CTRLD ”&#xff1b;使用“CTRL滚轮”即可&#xff1b; ctrl /-&#xff0c;是用来展开/收起代码的&#xff1b; 比如&#xff1a;js 的多行注释是 shiftalt…

电脑开机速度慢怎么解决?

电脑开机速度慢怎么解决&#xff1f;电脑开机速度慢的原因可以是多方面的&#xff0c;以下是一些常见的原因&#xff1a; 启动项过多&#xff1a; 许多软件在系统启动时会自动启动&#xff0c;导致启动项过多&#xff0c;从而延长了开机时间。过时的驱动程序&#xff1a; 设备…

NFTScan | 09.02~09.08 NFT 市场热点汇总

欢迎来到由 NFT 基础设施 NFTScan 出品的 NFT 生态热点事件每周汇总。 周期&#xff1a;2024.09.02~ 2024.09.08 NFT Hot News 01/ 数据&#xff1a;NFT 8 月销售额跌破 4 亿美元&#xff0c;创年内新低 9 月 2 日&#xff0c;数据显示&#xff0c;8 月 NFT 的月销售额仅为 …

【计算机网络 - 基础问题】每日 3 题(一)

✍个人博客&#xff1a;Pandaconda-CSDN博客 &#x1f4e3;专栏地址&#xff1a;http://t.csdnimg.cn/fYaBd &#x1f4da;专栏简介&#xff1a;在这个专栏中&#xff0c;我将会分享 C 面试中常见的面试题给大家~ ❤️如果有收获的话&#xff0c;欢迎点赞&#x1f44d;收藏&…

Spring Boot 注解探秘:Bean 管理的艺术

在 Spring Boot 应用开发中&#xff0c;Bean 的管理是核心功能之一。Spring Boot 提供了一套强大的注解系统&#xff0c;帮助开发者轻松管理 Bean 的生命周期和依赖注入。本文将深入探讨 Spring Boot 中常用的 Bean 处理注解及其应用场景。 一、Component注解 Component是一个…

第L6周:机器学习-随机森林(RF)

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 目标&#xff1a; 1.什么是随机森林&#xff08;RF&#xff09; 随机森林&#xff08;Random Forest, RF&#xff09;是一种由 决策树 构成的 集成算法 &#…

python库安装失败问题

pip install XXXX 报错信息如下 D:\Dev>pip install D:\Dev\robotlib-0.0.33.tar.gz DEPRECATION: Loading egg at d:\app\dev\python\lib\site-packages\fs11a3_package-1.3-py3.11.egg is deprecated. pip 24.3 will enforce this behaviour change. A possible replace…

mac安装swoole过程

1.很重要的是得根据自己环境的php版本来选择swoole版本&#xff01;否则都是做无用功。 Swoole 文档 2.通常pecl install swoole是安装最新版本的&#xff0c;当然安装的方式很多种&#xff0c;这里选择编译安装&#xff0c;因为可以选择不同的swoole版本进行安装&#xff0c;…

CTF中Web题目的常见题型及解题方法

基础知识类题目# 考察基本的查看网页源代码、HTTP请求、修改页面元素等。 这些题很简单&#xff0c;比较难的比赛应该不会单独出&#xff0c;就算有因该也是Web的签到题。 实际做题的时候基本都是和其他更复杂的知识结合起来出现。 姿势&#xff1a;恶补基础知识就行 查看网…

【无人机设计与控制】固定翼四旋翼无人机UAV俯仰姿态飞行模糊自整定PID控制Simulink建模

摘要 本研究设计了一种基于模糊自整定PID控制的固定翼四旋翼无人机俯仰姿态控制系统。利用Simulink建立了无人机俯仰控制系统模型&#xff0c;通过模糊控制器自适应调节PID参数&#xff0c;实现了对无人机俯仰角度的精确控制。实验结果表明&#xff0c;该控制策略在不同飞行状…

Java中NoSQL 与分布式数据库

Java 中的 NoSQL 与分布式数据库 随着大数据、云计算和分布式系统的快速发展&#xff0c;传统的关系型数据库&#xff08;如 MySQL、PostgreSQL 等&#xff09;在处理大规模数据时往往会遇到扩展性和性能上的瓶颈。为了解决这些问题&#xff0c;NoSQL 数据库和分布式数据库应运…

启动 Spring Boot 项目时指定特定的 application.yml 文件位置

java -jar your-spring-boot-app.jar --spring.config.locationfile:/path/to/your/config/application.yml your-spring-boot-app.jar 是你的 Spring Boot 应用的 JAR 文件名。file:/path/to/your/config/application.yml 是配置文件的绝对路径。 如果你有多个配置文件&#…

机器学习--神经网络

神经网络 计算 神经网络非常简单&#xff0c;举个例子就理解了&#xff08;最后一层的那个写错了&#xff0c;应该是 a 1 ( 3 ) a^{(3)}_1 a1(3)​&#xff09;&#xff1a; n o t a t i o n notation notation&#xff1a; a j ( i ) a^{(i)}_j aj(i)​ 表示第 i i i 层的…

嵌入式学习路线+嵌入式校招建议 嵌入式学习面试规划

随着物联网、人工智能以及5G等技术的迅猛发展&#xff0c;嵌入式系统的需求逐渐增多。作为毕业生&#xff0c;如何制定一个合理的学习路线&#xff0c;以确保在找工作、参加校招时有足够的竞争力&#xff0c;是非常重要的。我会为你提供一个更加详细、系统的学习路线建议&#…