LeetCode刷题 | Day 3 分割等和子集(Partition Equal Subset Sum)

LeetCode刷题 | Day 3 分割等和子集(Partition Equal Subset Sum)


文章目录

  • LeetCode刷题 | Day 3 分割等和子集(Partition Equal Subset Sum)
  • 前言
  • 一、题目概述
  • 二、解题方法
    • 2.1 动态规划思想
      • 2.1.1 思路讲解
      • 2.1.2 伪代码 + 逐步输出示例
      • 2.1.3 Python代码如下
      • 2.1.4 C++代码如下
  • 三、英语词汇


前言

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 思路讲解

Ps: 动态规划(Dynamic Programming)特征
- 最优子结构:
- 动态规划要求问题具有最优子结构性质,即问题的最优解包含其子问题的最优解。
- 重叠子问题:
- 动态规划需要问题具有重叠子问题性质,即不同的子问题在求解时会重复出现。
- 状态转移方程:
- 动态规划通过状态转移方程将问题分解为子问题,并通过子问题的解来推导原问题的解。
- 全局最优解:
- 动态规划通过考察所有可能的子问题组合来确保找到全局最优解。
- 记忆化或表格法:
- 动态规划通常使用记忆化搜索或自底向上的表格法来避免重复计算。

  • 动态规划策略

    • 本题思路主要是通过递归的方式遍历到任意一个数组的全部子序列,然后在遍历的过程中判断当前子序列是否满足和为原数组一半的条件。
  • 具体步骤

    1. 求和与奇偶性检查:

      • 先计算数组 nums 的总和 total。 如果 total 是奇数,则不可能将数组分成两个和相等的子集,因为奇数不能被均分,所以直接返回False。 如果 total 是偶数,那么我们需要找到一个子集,其和为 total // 2,称之为 half。
    2. 递归与缓存:

      • 定义一个递归函数 dp(i, s),表示在考虑前 i 个元素的情况下,是否可以得到和为 s 的子集。
    3. 利用 Python 的 @cache

      • 装饰器(或者等价的 functools.lru_cache)来缓存递归结果,避免重复计算,提高效率。
    4. 递归的边界条件与状态转移:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/22928.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

电脑显示找不到steam_api.dll,无法继续执行代码的详细解决办法

电脑显示找不到steam_api.dll,无法继续执行代码?其实会造成这种原因,注意是由于操作不当或者是中了病毒而导致的,我们想要解决steam_api.dll的丢失还是比较简单的,目前有多种的steam_api.dll修复方法,今天我们就来详细…

前端如何去除本地版本号缓存

前端去除本地版本号缓存的方法有多种&#xff0c;下面是一些常见且实用的方法&#xff0c;结合参考文章中的信息进行归纳和总结&#xff1a; 使用meta标签 在HTML页面的<head>区域中添加以下meta标签&#xff1a;<meta http-equiv"pragma" content"no-…

MySQL数据库常见工具的基础使用_1

在上一篇文章中提到了对MySQL数据库进行操作的一些常见工具 mysqlcheck mysqlcheck是一个用于数据库表的检查&#xff0c;修复&#xff0c;分析和优化的一个客户端程序 分析的作用是查看表的关键字分布,能够让sql生成正确的执行计划(支持InnoDB,MyISAM,NDB)检查的作用是检查…

前端逆向之下载canvas引用的图片

前端逆向之下载canvas引用的图片 一、来源二、解决三、如果在Network这里也找不到呢&#xff1f; 一、来源 当我们用dom检查器的时候无法选中想要扒下来的图片&#xff0c;只能选中canvas&#xff0c;这种时候该怎么办呢&#xff1f; 二、解决 这个时候应该换个脑子&#xf…

怎么排查native层的bug

方法一&#xff1a; android studio debug 直接运行&#xff0c;LLBD 不要打断点。会自动定位到错误 方法二&#xff1a;错误日志分析 ---》奔溃后&#xff0c;在logcat中查询SIGSEGV信号量。 ---》在Device Explorer中 data/tombstones 里就有日志信息。 备注:。。。。$su…

AI菜鸟向前飞 — LangChain系列之十六 - Agent系列:从现象看机制(下篇)一款“无需传递中间步骤“的Agent

前言 AI菜鸟向前飞 — LangChain系列之十四 - Agent系列&#xff1a;从现象看机制&#xff08;上篇&#xff09; AI菜鸟向前飞 — LangChain系列之十五 - Agent系列&#xff1a;从现象看机制&#xff08;中篇&#xff09;一个Agent的“旅行” 回顾前两篇文章&#xff0c;大家会…

endnote IEEEtran 参考文献 输出Latex

文章目录 参考文献Latex1. 新建格式1.1 新建BibTeX Export样式文件1.2 保存自定义文献格式 2 修改2.1 修改Journal Names 为简写2.2 修改Author Lists2.3 修改 模版 Templates 3. 特殊字符作者名字标题 4. 增加期刊简写4.1 删除已有简写的Term Lists 4.2 下载最新的Term LIsts4…

ApsaraMQ Copilot for RocketMQ:消息数据集成链路的健康管家

作者&#xff1a;文婷 引言 如何正确使用消息队列保证业务集成链路的稳定性&#xff0c;是消息队列用户首要关心的问题。ApsaraMQ Copilot for RocketMQ 从集成业务稳定性、成本、性能等方面帮助用户更高效地使用产品。 背景 消息队列产品通过异步消息的传递&#xff0c;来…

git环境代码版本控制

初装git环境需要配置用户名和邮箱&#xff0c;否则git会提示&#xff1a;please tell me who you are. 你需要运行命令来配置你的用户名和邮箱&#xff1a; $ git config --global user.name "superGG1990” $ git config --global user.email “superGG1990163.com” 注意…

Linux shell编程学习笔记55:hostname命令——获取或设置主机名,显示IP地址和DNS、NIS

0 前言 2024年的网络安全检查又开始了&#xff0c;对于使用基于Linux的国产电脑&#xff0c;我们可以编写一个脚本来收集系统的有关信息。其中主机名也是我们要收集的信息之一。 1. hostname命令 的功能、格式和选项说明 我们可以使用命令 hostname --help 来查看hostname命令…

深入了解 Android 中的 system.img

1. 简介 1.1 什么是 system.img&#xff1f; 在 Android 系统中&#xff0c;system.img 是一个关键的系统镜像文件&#xff0c;它包含了 Android 操作系统的核心组件、系统应用程序以及供应商提供的驱动程序和库文件。这个镜像文件以一种特定的格式存储整个系统文件系统&…

AV1视频编码格式

背景&#xff1a;开发进行技术分享&#xff0c;给出了AV1与VP8和H.264的编码效果对比图。 优点&#xff1a;编码速度快、性能消耗低、同码率下画质更清晰、同画质下视频压缩率更高。此外&#xff0c;相比于H.264、H.265&#xff0c; AV1属于开放式的视频编码标准&#xff0c;不…

如何检查网站文件是否有病毒

本周有一个客户&#xff0c;购买Hostease的主机&#xff0c; 客户购买的是Linux虚拟主机&#xff0c;带cPanel面板的。询问我们的在线客服&#xff0c;他想检查下他的网站程序是否有病毒文件。Hostease虚拟主机附带病毒扫描软件功能&#xff0c;可以协助检查网站程序是否有病毒…

四足机器人步态仿真(二)PyBullet 机械臂运动学仿真(以绘制圆形路径为例)

观前提醒&#xff1a;本章主要内容是通过PyBullet仿真kuka机械臂&#xff0c;并控制机械臂末端按照预定轨迹运动 一、什么是运动学&#xff1f; 运动学是物理学的一个分支&#xff0c;专注于物体的运动描述&#xff0c;包括位移、速度、加速度等&#xff0c;而不考虑这些运动是…

【c++设计模式17】行为模式2:命令模式(Command Pattern)

【c设计模式17】行为模式2&#xff1a;命令模式&#xff08;Command Pattern&#xff09; 一、定义二、适用场景三、过程四、命令模式类图五、C示例代码六、使用注意事项 原创作者&#xff1a;郑同学的笔记 原创地址&#xff1a;https://zhengjunxue.blog.csdn.net/article/det…

蓝牙中央管理器初始化详解

文章目录 蓝牙中央管理器初始化详解1、接口解释2、Options解释1、CBCentralManagerOptionShowPowerAlertKey2、CBCentralManagerOptionRestoreIdentifierKey3、CBCentralManagerOptionDeviceAccessForMedia 蓝牙中央管理器初始化详解 1、接口解释 /*!* method initWithDeleg…

做外贸你以为客户会懂,但是你还是要讲出来!

很多人都认为&#xff0c;我们公司介绍里啥都有&#xff0c;公司规模有多大&#xff0c;认证有哪些&#xff0c;产品能做什么&#xff1f;我们写在那里&#xff0c;客户就应该懂。 其实&#xff0c;不是的。 客户真的关注不了那么多&#xff0c;可能看到了&#xff0c;也就是看…

真心建议女生疯狂转行IT这5个方向

低学历女生们&#xff0c;不要再固守在文员、客服等岗位上了&#xff01;这些看似轻松却局限性强的工作已经过时了。现在是时候换个思路&#xff0c;尝试一些热门、好就业的IT职业了&#xff01; . ✅ 鸿蒙开发&#xff1a; 平均月&#x1f4b0;&#xff1a;15~30k 入门难度&am…

运维工具 - SFTP 和 FTP 的区别?

SFTP 和 FTP 的区别有三点 连接方式 SFTP 是在客户端和服务器之间通过 SSH 协议建立的安全连接来传输文件&#xff0c;而 FTP 则是 TCP 端口 21 上的控制连接建立连接。 安全性 SFTP 使用加密传输认证信息来传输数据&#xff0c;因此 SFTP 相对于 FTP 更安全的。 效率 SF…

代码杂谈 之 pyspark如何做相似度计算

在 PySpark 中&#xff0c;计算 DataFrame 两列向量的差可以通过使用 UDF&#xff08;用户自定义函数&#xff09;和 Vector 类型完成。这里有一个示例&#xff0c;展示了如何使用 PySpark 的 pyspark.ml.linalg.Vectorspyspark.sql.functions.udf 来实现这一功能&#xff1a…