LeetCode hot100-89

devtools/2024/12/23 23:20:21/

https://leetcode.cn/problems/partition-equal-subset-sum/description/?envType=study-plan-v2&envId=top-100-liked

416. 分割等和子集
已解答
中等
相关标签
相关企业
给你一个 只包含正整数 的 非空 数组 nums 。请你判断是否可以将这个数组分割成两个子集,使得两个子集的元素和相等。

问题分析:

目标是将数组分成两个子集,并且这两个子集的和相等。假设数组 nums 的总和为 S。
如果 S 是奇数,显然无法将数组分割成两个和相等的子集,因为两个相等的子集的和必然是偶数。
如果 S 是偶数,目标是找到一个子集,使得其和为 S / 2。也就是说,问题转化为 判断是否存在一个子集,其和为 S / 2。
动态规划解法:

定义 dp[i] 为是否存在一个子集,其和为 i。
初始化 dp[0] = true,表示和为 0 的子集是存在的(即空子集)。
对每个数 num,从后往前更新 dp 数组:如果 dp[j - num] 为 true,则 dp[j] 也可以为 true,表示可以选择该 num 来组成和为 j 的子集。

第二层循环从target到num自己才能保证dp被更新

类似于
处理 num = 1:
我们更新 dp[j] 从 j = 11 到 j = 1:
dp[11] = dp[11] || dp[11 - 1] = false || false = false
dp[10] = dp[10] || dp[10 - 1] = false || false = false
dp[9] = dp[9] || dp[9 - 1] = false || false = false
dp[8] = dp[8] || dp[8 - 1] = false || false = false
dp[7] = dp[7] || dp[7 - 1] = false || false = false
dp[6] = dp[6] || dp[6 - 1] = false || false = false
dp[5] = dp[5] || dp[5 - 1] = false || false = false
dp[4] = dp[4] || dp[4 - 1] = false || false = false
dp[3] = dp[3] || dp[3 - 1] = false || false = false
dp[2] = dp[2] || dp[2 - 1] = false || false = false
dp[1] = dp[1] || dp[1 - 1] = false || true = true → dp[1] = true
class Solution {public boolean canPartition(int[] nums) {int sum=0;for(int i=0;i<nums.length;i++){sum += nums[i];}if(sum%2!=0){return false;}sum=sum/2;boolean[] dp = new boolean[sum+1];dp[0]=true;for(int num : nums){for(int i=sum;i>=num;i--){dp[i]=dp[i]||dp[i-num];}}return dp[sum];}
}

http://www.ppmy.cn/devtools/144826.html

相关文章

Chapter 3-1. Detecting Congestion in Fibre Channel Fabrics

Chapter 3. Detecting Congestion in Fibre Channel Fabrics This chapter covers the following topics: 本章包括以下主题: Congestion detection workflow. Congestion detection metrics. Congestion detection metrics and commands on Cisco MDS switches. Automatic A…

金碟中间件-AAS-V10.0安装

金蝶中间件AAS-V10.0 AAS-V10.0安装 1.解压AAS-v10.0安装包 unzip AAS-V10.zip2.更新license.xml cd /root/ApusicAS/aas# 这里要将license复制到该路径 [rootvdb1 aas]# ls bin docs jmods lib modules templates config domains …

CTF入门:以Hackademic-RTB1靶场为例初识夺旗

一、网络扫描 靶机ip地址为192.168.12.24 使用nmap工具进行端口扫描 nmap -sT 192.168.12.24 二、信息收集 1、80端口探索 靶机开放了80和22端口&#xff0c;使用浏览器访问靶机的80端口&#xff0c;界面如下&#xff1a; 点击target发现有跳转&#xff0c;并且url发生相应变…

python学opencv|读取图像(十八)使用cv2.line创造线段

【1】引言 前序已经完成了opencv基础知识的学习&#xff0c;我们已经掌握了处理视频和图像的基本操作。相关文章包括且不限于&#xff1a; python学opencv|读取图像&#xff08;三&#xff09;放大和缩小图像_python(1)使用opencv读取并显示图像;(2)使用opencv对图像进行缩放…

Git进阶:本地或远程仓库如何回滚到之前的某个commit

在Git的使用过程中&#xff0c;我们经常会遇到需要回滚到之前某个commit的情况。无论是为了修复错误、撤销更改&#xff0c;还是为了重新组织代码&#xff0c;回滚到特定commit都是一个非常有用的技能。本文将介绍几种常用的回滚方法&#xff0c;帮助读者更好地掌握Git版本控制…

libilibi项目总结(18)FFmpeg 的使用

FFmpeg工具类 import com.easylive.entity.config.AppConfig; import com.easylive.entity.constants.Constants; import org.springframework.stereotype.Component;import javax.annotation.Resource; import java.io.File; import java.math.BigDecimal;Component public c…

梯度(Gradient)和 雅各比矩阵(Jacobian Matrix)的区别和联系:中英双语

雅各比矩阵与梯度&#xff1a;区别与联系 在数学与机器学习中&#xff0c;梯度&#xff08;Gradient&#xff09; 和 雅各比矩阵&#xff08;Jacobian Matrix&#xff09; 是两个核心概念。虽然它们都描述了函数的变化率&#xff0c;但应用场景和具体形式有所不同。本文将通过…

【Spring】探秘 SpringBoot 配置文件:解锁验证码背后的实现逻辑

前言 &#x1f31f;&#x1f31f;本期讲解关于Spring IOC&DI的详细介绍~~~ &#x1f308;感兴趣的小伙伴看一看小编主页&#xff1a;GGBondlctrl-CSDN博客 &#x1f525; 你的点赞就是小编不断更新的最大动力 &#x1f386;那么…