代码随想录算法训练营|day42

第九章 动态规划

背包类型 求解方法
0/1背包 外循环nums,内循环target,target倒序且target>=nums[i]
完全背包 外循环nums,内循环target,target正序且target>=nums[i]
组合背包 外循环target,内循环nums,target正序且target>=nums[i]

416.分割等和子集

该问题转换为在数组中找到元素和target=sum(nums)/2即可,为0/1背包问题,dp[i]表示是否存在子集和为i。

初始化:dp[0]=true,表示和为0,不需要选取任何元素,为真

如果和为奇数或者数组中最大值大于target无法分成两个等和子集

go 复制代码
func canPartition(nums []int) bool {
	sum, maxNum := 0, 0
	for _, num := range nums {
		maxNum = max(maxNum, num)
		sum += num
	}
	if sum%2 != 0 {
		return false
	}
	target := sum / 2
	if maxNum > target {
		return false
	}
	dp := make([]bool, target + 1)
	dp[0] = true
	for _, num := range nums {
		for i := target; i >= num; i-- {
			dp[i] = dp[i] || dp[i - num]
		}
	}
	return dp[target]
}

代码随想录文章详解

01背包理论基础
01背包理论基础(滚动数组)
416.分割等和子集

相关推荐
前端小L2 小时前
贪心算法专题(十):维度权衡的艺术——「根据身高重建队列」
javascript·算法·贪心算法
方得一笔2 小时前
自定义常用的字符串函数(strlen,strcpy,strcmp,strcat)
算法
Xの哲學3 小时前
Linux SMP 实现机制深度剖析
linux·服务器·网络·算法·边缘计算
wuk9983 小时前
使用PCA算法进行故障诊断的MATLAB仿真
算法·matlab
额呃呃3 小时前
二分查找细节理解
数据结构·算法
无尽的罚坐人生3 小时前
hot 100 283. 移动零
数据结构·算法·双指针
永远都不秃头的程序员(互关)3 小时前
C++动态数组实战:从手写到vector优化
c++·算法
水力魔方4 小时前
武理排水管网模拟分析系统应用专题5:模型克隆与并行计算
数据库·c++·算法·swmm
谈笑也风生5 小时前
经典算法题型之排序算法(三)
java·算法·排序算法
大佬,救命!!!6 小时前
对算子shape相关的属性值自动化处理
python·算法·自动化·学习笔记·算子·用例脚本·算子形状