代码随想录算法训练营|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.分割等和子集

相关推荐
Trent198510 分钟前
影楼精修-肤色统一算法解析
图像处理·人工智能·算法·计算机视觉
feifeigo12314 分钟前
高光谱遥感图像处理之数据分类的fcm算法
图像处理·算法·分类
北上ing1 小时前
算法练习:19.JZ29 顺时针打印矩阵
算法·leetcode·矩阵
.格子衫.2 小时前
真题卷001——算法备赛
算法
XiaoyaoCarter2 小时前
每日一道leetcode
c++·算法·leetcode·职场和发展·二分查找·深度优先·前缀树
Hygge-star3 小时前
【数据结构】二分查找5.12
java·数据结构·程序人生·算法·学习方法
June`4 小时前
专题二:二叉树的深度搜索(二叉树剪枝)
c++·算法·深度优先·剪枝
好吃的肘子5 小时前
Elasticsearch架构原理
开发语言·算法·elasticsearch·架构·jenkins
胡耀超6 小时前
霍夫圆变换全面解析(OpenCV)
人工智能·python·opencv·算法·计算机视觉·数据挖掘·数据安全
软行6 小时前
LeetCode 每日一题 3341. 到达最后一个房间的最少时间 I + II
数据结构·c++·算法·leetcode·职场和发展