LeetCode 416 分割等和子集

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

示例 1:

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

输出:true

解释:数组可以分割成 1, 5, 511

示例 2:

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

输出:false

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

提示:

1 <= nums.length <= 200

1 <= numsi <= 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]
相关推荐
阿正的梦工坊5 分钟前
【Rust】07-错误处理:Option、Result 与 ? 运算符
开发语言·算法·rust
烬羽9 分钟前
从零理解树与二叉树:用 JS 带你手撕遍历和递归
javascript·数据结构
YHL18 分钟前
🚀从零理解树与二叉树 —— 概念、实现与遍历
前端·javascript·数据结构
JieE2121 小时前
JS 到底有多少种数据类型?从ECMA规范到内存本质,一文彻底搞懂
javascript·数据结构·面试
努力努力再努力wz1 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表
八解毒剂1 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
运行时记录2 小时前
别再手动写提示词了 — SkillOpt 让技能文档自己进化
算法
啦啦啦啦啦zzzz2 小时前
算法总结(二分查找、双指针)
c++·算法
qq_8573058193 小时前
python语法
开发语言·python·算法
DXM05213 小时前
第9期|从机器学习到深度学习:AI遥感解译的进化逻辑
人工智能·算法·计算机视觉