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

产业协会建设网站方案怎么建设一个响应式网站

产业协会建设网站方案,怎么建设一个响应式网站,wordpress运行环境,广州品牌网站设计公司LeetCode刷题 | Day 4 分割等和子集(Partition Equal Subset Sum)自底向上动态规划 文章目录 LeetCode刷题 | Day 4 分割等和子集(Partition Equal Subset Sum)自底向上动态规划前言一、题目概述二、解题方法2.1 一维表格的自底向上动态规划2.1.1 思路讲解2.1.2 伪代码 + 逐…

LeetCode刷题 | Day 4 分割等和子集(Partition Equal Subset Sum)自底向上动态规划


文章目录

  • LeetCode刷题 | Day 4 分割等和子集(Partition Equal Subset Sum)自底向上动态规划
  • 前言
  • 一、题目概述
  • 二、解题方法
    • 2.1 一维表格的自底向上动态规划
      • 2.1.1 思路讲解
      • 2.1.2 伪代码 + 逐步输出示例
      • 2.1.3 Python代码如下
      • 2.1.4 C++代码如下
    • 2.2 二维表格的自底向上动态规划
      • 2.2.1 思路讲解
      • 2.2.2 伪代码 + 逐步输出示例
      • 2.2.3 Python代码如下
      • 2.2.4 C++代码如下
    • 2.3 方法对比
  • 三、英语词汇


前言

LeetCode位置:416. 分割等和子集

日常刷题,维持手感,同步学习英语,刷题顺序参考B站UP@justyyuk的系列视频,感兴趣的点波关注。
学海无涯,大路千万,感恩此程,彼此真诚陪伴!
在这里插入图片描述
Ps:第一次刷到的道友留步,这里拉齐一下信息。文章主要记录视频中的主要内容,算法思路会按照个人理解,用伪代码+举例每步输出的方式呈现。代码部分会以Python和C++语法进行呈现。文章最后会总结一些英语词汇。OK,就啰嗦这么多,开始进步[干杯🐱‍👓]


一、题目概述

Day3

输入:nums列表
输出:bool值,表示原始列表是否存在和相等的两个子列表

PS:

  1. 子序列 (Subsequence/Subset):

    • 子序列是通过从原始序列中删除一些或不删除任何元素且不改变剩余元素顺序而得到的序列。
    • 例子:对于序列 [1, 2, 3, 4],[1, 3, 4] 和 [2, 4] 是子序列。
    • 注意:[1, 4, 3] 不是 子序列,因为顺序改变了。
  2. 子列表 (Sublist)

    • 子列表是列表的连续部分,意味着元素必须是连续的。
    • 例子:对于列表 [1, 2, 3, 4],[2, 3] 和 [1, 2, 3]是子列表。
    • 注意:[1, 3] 不是 子列表,因为它不是连续的。
  3. 子数组 (Subarray):

    • 类似于子列表,子数组是数组的连续部分。
    • 例子:对于数组 [1, 2, 3, 4],[2, 3] 和 [1, 2, 3] 是子数组。
    • 注意:[1, 3] 不是 子数组,因为它不是连续的。
  • 在许多情况下,当数据结构是数组或列表时,“子列表”和“子数组”可以互换使用,但“子数组”一词专门用于数组。

二、解题方法

2.1 一维表格的自底向上动态规划

2.1.1 思路讲解

动态规划策略 :
本题与昨天的是同一道题,不过这次采用自底向上(表格法)的动态规划策略。此处有两种方法,一种使用到一维表格,一种使用二维表格。

  • 一维表格:用表格长度表示待达成目标,即数组和的一半(+1),表格内的值(True/False)表示子序列是否选择当前元素

    • 表格长度:表格 dp 的长度为 half + 1,其中 half 是数组总和的一半。这意味着我们试图判断是否存在一个子集,使其和为 0 到 half 之间的任何值。
    • 表格的值:dp[i] 是一个布尔值,表示是否存在一个子集,其和等于 i。
    • 初始化:dp[0] 被初始化为 True,因为和为 0 的子集总是存在的(空集)。其他位置被初始化为 False。
    • 状态转移:
    • 对于数组中的每一个元素 num,从后向前遍历 dp 数组(从 half 到 num),更新 dp 数组的值。
    • 更新规则为:dp[i] = dp[i] or dp[i - num]。这意味着如果存在一个子集和为 i - num,那么加上 num 后,和为 i 的子集也存在。

具体步骤:

  1. 计算总和:total = sum(nums),如果 total 是奇数,返回 False。
  2. 计算目标子集和:half = total // 2。
  3. 初始化 dp 数组:dp = [False for _ in range(half + 1)],并设 dp[0] = True。
  4. 遍历 nums 更新 dp 数组:
    • 对每个 j(来自 nums),从 half 到 j 更新 dp。
    • 如果 j <= i,则 dp[i] = dp[i] or dp[i - j]。
  5. 返回 dp[half],表示是否存在一个子集其和为 half。

2.1.2 伪代码 + 逐步输出示例

# 伪代码示例
函数 canPartition(nums):total = nums 的和如果 total 是奇数:返回 Falsehalf = total // 2dp = 长度为 half + 1 的布尔数组,所有元素初始化为 Falsedp[0] = True对于 nums 中的每一个 num:从 half 到 num 遍历 i:如果 dp[i - num] 为 True:dp[i] = True返回 dp[half]# 逐步输出示例:
输入:[1, 2, 1]
初始化
•	total = 1 + 2 + 1 = 4
•	half = 4 // 2 = 2
•	dp = [True, False, False](长度为 half + 1)
处理第一个元素 1
•	遍历 i 从 21(倒序)o	i = 2: dp[2] = dp[2] or dp[1] -> False or False = Falseo	i = 1: dp[1] = dp[1] or dp[0] -> False or True = True
•	更新后的 dp: [True, True, False]
处理第二个元素 2
•	遍历 i 从 22(倒序)o	i = 2: dp[2] = dp[2] or dp[0] -> False or True = True
•	更新后的 dp: [True, True, True]
处理第三个元素 1
•	遍历 i 从 21(倒序)o	i = 2: dp[2] = dp[2] or dp[1] -> True or True = Trueo	i = 1: dp[1] = dp[1] or dp[0] -> True or True = True
•	更新后的 dp: [True, True, True]
最终结果
•	返回 dp[half]
http://www.yayakq.cn/news/541850/

相关文章:

  • 网站建设咨询云尚网络wordpress 新建表
  • 罗湖网站建设费用分类信息网站手机版
  • WordPress网站转HTPPS刚做还网站第一时间抓取
  • wordpress域名根管网站建设 app 优化
  • 神农架网站设计百度做网站骗人到哪里去投诉
  • 网站建设之婚礼摄影网站设计替别人做设计的网站多少钱
  • 单位 内网网站建设wordpress微信公众号登录界面
  • 品牌网站建设解决方网站建设 三合一
  • 做网站怎么排版创意设计方法有哪些
  • 你的网站赚钱吗搭建一个购物网站
  • wordpress调用网站最新文章中国建设银行官网个人网上银行
  • 哪个网站diy做宝宝衣服如何查找织梦网站后台
  • 东莞模板建站哪家好杭州专业seo服务公司
  • 公司网站制作公司排名爱心助学网站建设
  • 义乌建设网站怎么给公司建网站
  • 自己怎么做卖东西的网站ps软件下载手机版免费
  • 用dw做红米网站wordpress纯静态化插件
  • 顺义区快速建站木马设计公司官网
  • 班级网站建设论文百度搜索引擎优化公司哪家强
  • 江苏省建筑工程集团有限公司网站图片加载优化
  • 营销型网站单页滨州五学一做考试网站
  • 用vue开发的网站帝国cms网站制作
  • 吴江那里有做公司网站的国外购物平台有哪些
  • 单页面的网站模板免费下载陵园网站建设价格
  • 做网页链接网站莱芜区政协网站
  • 东营网站建设服务小昆山网站建设
  • html5做手机网站买了个区域名怎么做网站
  • 网站怎么做流量统计上海十大广告公司排名
  • 网站搜索功能代码wordpress 分类菜单高亮
  • app介绍网站模板四川建设行政主管部门官方网站