LeetCode 416 分割等和子集

给你一个 只包含正整数 的 非空 数组 nums 。请你判断是否可以将这个数组分割成两个子集,使得两个子集的元素和相等。

示例 1:

输入:nums = [1,5,11,5]

输出:true

解释:数组可以分割成 [1, 5, 5] 和 [11] 。

示例 2:

输入:nums = [1,2,3,5]

输出:false

解释:数组不能分割成两个元素和相等的子集。

提示:

1 <= nums.length <= 200

1 <= nums[i] <= 100

Python代码:

python 复制代码
from typing import List

class Solution:
    def canPartition(self, nums: List[int]) -> bool:
        total = sum(nums)
        # 若总和为奇数,直接返回false
        if total % 2 != 0:
            return False
        
        target = total // 2
        # dp[i] 表示能否组成和为i的子集
        dp = [False] * (target + 1)
        dp[0] = True  # 基础情况:和为0的子集存在(空集)
        
        for num in nums:
            # 倒序遍历,避免同一元素被多次使用
            for i in range(target, num - 1, -1):
                if dp[i - num]:
                    dp[i] = True
        
        # 若能组成和为target的子集,则返回true
        return dp[target]
相关推荐
LuminousCPP6 分钟前
数据结构 - 线性表第三篇:基于顺序表实现 C 语言通讯录(基础功能篇)
c语言·数据结构·经验分享·笔记·算法
_日拱一卒10 分钟前
LeetCode:114二叉树展开为链表
java·开发语言·算法
无小道20 分钟前
Redis——哈希类型相关指令
redis·算法·哈希算法
凌波粒22 分钟前
LeetCode--513.找树左下角的值(二叉树)
java·算法·leetcode
一个不知名程序员www22 分钟前
算法学习入门---算法题DAY1
c++·算法
子琦啊27 分钟前
构造函数、this指向和原型链机制
javascript·算法·贴图
WHS-_-202229 分钟前
Millimeter Wave ISAC-SLAM: Framework and RFSoC Prototype
人工智能·算法·原型模式
吃好睡好便好30 分钟前
在Matlab中绘制杆状图
开发语言·学习·算法·matlab·信息可视化
带带弟弟学爬虫__31 分钟前
dyAPP数据采集-个人主页、发布、搜索、评论
服务器·python·算法·flutter·java-ee·django
sali-tec37 分钟前
C# 基于OpenCv的视觉工作流-章75-线-线角度
图像处理·人工智能·opencv·算法·计算机视觉