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

相关推荐
2401_857683547 分钟前
C++中的原型模式
开发语言·c++·算法
s1hiyu17 分钟前
C++动态链接库开发
开发语言·c++·算法
(❁´◡`❁)Jimmy(❁´◡`❁)18 分钟前
CF2188 C. Restricted Sorting
c语言·开发语言·算法
We་ct18 分钟前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
星火开发设计22 分钟前
C++ 预处理指令:#include、#define 与条件编译
java·开发语言·c++·学习·算法·知识
mit6.8241 小时前
dijk|tire+floyd+dp %
算法
独自破碎E1 小时前
【总和拆分 + 双变量遍历】LCR_012_寻找数组的中心下标
数据结构·算法
WBluuue1 小时前
Codeforces 1076 Div3(ABCDEFG)
c++·算法
u0109272711 小时前
模板编译期排序算法
开发语言·c++·算法
GIS瞧葩菜1 小时前
Cesium 轴拖拽 + 旋转圈拖拽 核心数学知识
人工智能·算法·机器学习