当前位置: 首页 > wzjs >正文

蓝色色调网站外贸获客软件

蓝色色调网站,外贸获客软件,网站开发安全小贴士,网站建设的公司做销售416. 分割等和子集 一、算法逻辑(每一步思路) ❓ 问题描述: 给定一个只包含正整数的数组 nums,判断是否可以将其分成两个子集,使得这两个子集的元素和相等。 ✅ 思路解析(DFS 记忆化) 1. 总…

416. 分割等和子集

一、算法逻辑(每一步思路)

❓ 问题描述:

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


✅ 思路解析(DFS + 记忆化)

1. 总和判断:
s = sum(nums)
  • 只有当总和是 偶数 时,才可能被分成两个相等的子集;
  • 否则直接返回 False
2. 定义目标:

我们目标是找到一个子集,使得其和为 target = s // 2


3. 定义状态:
dfs(i, j) 表示:是否可以从 nums[0..i] 中选出一些数,使得它们的和为 j
4. 状态转移逻辑:
  • 我们每个数都可以选或不选:
dfs(i, j) = dfs(i-1, j-nums[i])  # 选 nums[i]or dfs(i-1, j)          # 不选 nums[i]

前提是:

  • 当选 nums[i] 时,必须保证 j >= nums[i] 否则非法。
5. 边界条件:
  • i < 0 表示没有数可以选了,此时只有当 j == 0,才能说“成功凑出目标和”。

6. 初始调用:
dfs(len(nums)-1, s//2)
  • 从所有数中尝试凑出 s//2
7. 使用 @cache 实现记忆化,避免指数级重复递归。

二、算法核心点

✅ 核心思想:子集和问题 + 记忆化搜索

  • 本质是 0/1 背包问题:能不能从 nums 中挑若干个数,使它们的和为 target = s // 2
  • DFS 方式天然适合尝试所有选法;
  • 用记忆化优化重复状态访问,转为多项式级别复杂度。
class Solution:def canPartition(self, nums: List[int]) -> bool:@cachedef dfs(i:int, j:int)->bool:if i<0:return j==0return j>=nums[i] and dfs(i-1, j-nums[i]) or dfs(i-1, j)s = sum(nums)return s%2==0 and dfs(len(nums)-1, s//2)

三、复杂度分析

  • 时间复杂度:O(n × target)
    • 每个状态 (i, j) 最多访问一次;
    • i 最多为 nj 最多为 target = s//2
  • 空间复杂度:O(n × target)
    • 缓存表大小为 n × target
    • 递归栈深度最多为 n

总结表

维度

内容

✅ 思路逻辑

转化为是否可以从数组中选出若干数,使它们的和为总和的一半

✅ 核心技巧

记忆化搜索 + 状态定义 dfs(i, j)

✅ 时间复杂度

O(n × s//2),即 O(n × sum/2)

✅ 空间复杂度

O(n × sum/2),包括递归栈和缓存


✅ 示例演示

输入:

nums = [1, 5, 11, 5]

总和为 22,可以划分为 [11] 和 [1,5,5],输出为 True

http://www.dtcms.com/wzjs/171767.html

相关文章:

  • 做搜狗手机网站快速排网络优化工作应该怎么做
  • python做项目的网站新闻式软文
  • 好的网站和网页有哪些seo的理解
  • 做响应式网站设计图是多大的比较靠谱的电商培训机构
  • wordpress中文编辑器插件杭州网站优化
  • 网站的建设模式24小时自助下单平台网站便宜
  • 公司建设网站记什么费用镇江网页设计
  • 做海外网站深圳网站seo哪家快
  • 淘宝网站建设的详细策划百度搜索引擎优化的方法
  • 云南网站seo外包鱼头seo软件
  • 什么公司做网站最好营销网店推广的软文
  • wordpress同ip弹一次广告seo关键词优化技巧
  • 一流门户网站建设seo的形式有哪些
  • 那个网站做稻草交易推广拉新app哪几个靠谱
  • 360网站做推广西安网络推广优化培训
  • 北京营销型网站公司seo自学教程seo免费教程
  • 南宁网站建设索q.479185700日照网络推广公司
  • 网站做多个单页链接网络营销推广方案步骤
  • 做网站必备模板建站公司
  • 如何建设备案网站视频教程今日微博热搜榜前十名
  • php学什么可以做网站百度免费安装
  • asp网站免费电商平台怎么推广
  • 设计找图网站制作一个网站的流程有哪些
  • 张家口建设网站长沙靠谱关键词优化服务
  • 沂南建设局网站百度提交入口网址
  • 施工企业如何获取竞争优势seo优化的优点
  • 怎么做直播网站刷弹幕推广一次多少钱
  • 宿舍网站建设目的超云seo优化
  • anaconda可以做网站吗深圳搜索优化排名
  • 服务网站建设企业大连最好的做网站的公司