动态规划之背包问题(分割等和子集问题)

题目分析

给一个正整数的数组,让你分隔成两个相等的数组

通过观察,我们可以发现,总和是一定的,也就是sum,把sum分成两部分,每部分都是sun/2

转换为01背包问题,每个元素都是0或1,挑出的元素总和是sun/2,剩下的那部分就是sum/2了

算法原理

状态表示:借用01背包分析思路

dp[i][j]:选到i位置的元素时,所有的选法中总的元素和是否有等于j,是就存true,不是就存false

状态转移方程:根据最近的一步划分问题

dp[i][j]:选到i位置时,可以分两种情况,第一种选i,第二种不选i

第一种选i:选i代表你前面要凑出来dp[i-1][j-nums[i]],也就是在i-1前面要有j-nums[i],等你选i位置时就刚好能凑出来,这个注意要判断j-nums[i]是否存在,如果连这个都没有,那肯定是false,证明你单独选i这个都超过了;

第二种不选i:不选只要判断是否有dp[i-1][j];

dp[i][j]=dp[i-1][j]||dp[i-1][j-nums[i]]; 两种只要有一种是true即可,否则就是false

初始化:

dp[i][j]=dp[i-1][j]||dp[i-1][j-nums[i]];

用到的地方要注意有没有越界

所以初始化是可以多加一行多加一列,但要注意下标映射关系

返回值

dp[n][sum/2]

代码编写

优化

相关推荐
David Bates20 分钟前
代码随想录第41天:图论2(岛屿系列)
python·算法·图论
司小豆27 分钟前
视觉-语言基础模型作为高效的机器人模仿学习范式
人工智能·算法·机器人
oioihoii1 小时前
C++23 新特性:为 std::pair 的转发构造函数添加默认实参
算法·c++23
智者知已应修善业2 小时前
【验证哥德巴赫猜想(奇数)】2021-11-19 15:54
c语言·c++·经验分享·笔记·算法
-qOVOp-3 小时前
zst-2001 历年真题 设计模式
java·算法·设计模式
evolution_language3 小时前
LintCode第68题-二叉树的前序遍历,第67题-二叉树的后序遍历
数据结构·算法·新手必刷编程50题
passionSnail3 小时前
《用MATLAB玩转游戏开发:从零开始打造你的数字乐园》基础篇(2D图形交互)-俄罗斯方块:用旋转矩阵打造经典
算法·matlab·矩阵·游戏程序·交互
yxc_inspire3 小时前
C++STL在算法竞赛中的应用详解
c++·算法·stl
James. 常德 student3 小时前
leetcode-hot-100(哈希)
算法·leetcode·哈希算法
金融小师妹3 小时前
量化解析美英协议的非对称冲击:多因子模型与波动率曲面重构
大数据·人工智能·算法