刷题记录 贪心算法-4:53. 最大子数组和

news/2025/2/4 16:33:22/

题目:53. 最大子数组和

数字 n 代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且 有效的 括号组合。

示例 1:

输入:n = 3
输出:["((()))","(()())","(())()","()(())","()()()"]

示例 2:

输入:n = 1
输出:["()"]

提示:

  • 1 <= n <= 8

一、模式识别

1.算法>贪心算法

局部最优解:连续和为负时放弃连续和,重新开始连续和

局部到全局:选取多个子数组的最大连续和

反例:(象征性的写一下,能用贪心的都不会有,而且也不用证明)

代码随想录里也说这道题的贪心并不好想

不仅不好想,而且仔细想会发现连续和为负时放弃连续和只是一个必要条件,

2.动态规划

序列问题:经典动态规划问题,所以其实本题更容易想到动态规划解法

(1)定义:dp[i]: 以nums[i]为结尾的最大数字和

(2)递推公式:dp[i] = max(dp[i - 1] +num, num)

dp[i - 1]是以前一个数字为结尾的最大值

由于连续数组条件限制,因此在本轮中只能在加入以前的连续序列重新开始之间做出选择

(3)初始化:由递推,任意dp[i]依赖于dp[i - 1],需要从dp[0]开始

(4)遍历顺序:由递推,dp[i]依赖于dp[i - 1],需要从前往后

二、代码实现

1.暴力解法

连续子序列这么明确的条件,用两层嵌套循环分别表示起始点和终止点最容易实现了

python">class Solution:def maxSubArray(self, nums: List[int]) -> int:n = len(nums)ans = -inffor i, num in enumerate(nums):for j in range(i, n):sum_all = sum(nums[i: j + 1])if sum_all > ans:ans = sum_allreturn ans

但有个缺点:会超时 

2.算法>贪心算法

python">class Solution:def maxSubArray(self, nums: List[int]) -> int:n = len(nums)ans = -infcount = 0for i, num in enumerate(nums):count += numif count < num:count = numif count > ans:ans = countreturn ans

3.动态规划

python">class Solution:def maxSubArray(self, nums: List[int]) -> int:n = len(nums)dp = [-inf] * nans = dp[0] = nums[0]for i in range(1, n):dp[i] = max(dp[i - 1] + nums[i], nums[i])if dp[i] > ans:ans = dp[i]return ans

三、动态规划与算法>贪心算法的逻辑关系

仔细观察动态规划的递推公式dp[i] = max(dp[i - 1] +num, num)

dp[i - 1] +num和num的选择条件是是什么?

很明显是dp[i - 1]的值的正负号,与算法>贪心算法连续和为负时放弃连续和的条件完全吻合

因此,本题的关键就在于理解“连续”:

由于只能对连续子数组求和,

对于每一个数字,只需要在与上一个数字的连续和相加重新开始算连续和之间做出选择

不需要考虑当前数字与哪些数字求和能得到最大值

所以实际上对于本题而言:

动态规划解法就是算法>贪心算法的充分性证明,

算法>贪心算法就是动态规划的精简版

以下是算法>贪心算法到动态规划的一个过渡态写法:

python">class Solution:def maxSubArray(self, nums: List[int]) -> int:n = len(nums)ans = -infcount = 0for i, num in enumerate(nums):count += numif count < num:count = numif count > ans:ans = countreturn ans

注意相比与算法>贪心算法count的比较顺序是调换的


http://www.ppmy.cn/news/1569275.html

相关文章

XML DOM - 访问节点

通过 DOM&#xff0c;您能够访问 XML 文档中的每个节点。 尝试一下 - 实例 下面的实例使用 XML 文件 books.xml。 函数 loadXMLDoc()&#xff0c;位于外部 JavaScript 中&#xff0c;用于加载 XML 文件。 使用节点列表中的索引号来访问节点 本例使用 getElementsByTagname() …

neo4j入门

文章目录 neo4j版本说明部署安装Mac部署docker部署 neo4j web工具使用数据结构图数据库VS关系数据库 neo4j neo4j官网Neo4j是用ava实现的开源NoSQL图数据库。Neo4作为图数据库中的代表产品&#xff0c;已经在众多的行业项目中进行了应用&#xff0c;如&#xff1a;网络管理&am…

【后端】Flask

长期更新&#xff0c;建议关注收藏点赞&#xff01; 实例1 Jinja2 是 Flask 和 Django 使用的 模板引擎&#xff0c;它允许你在 HTML 中嵌入 Python 代码&#xff0c;以动态生成页面内容。Jinja2 语法类似于 Django 模板&#xff0c;并支持变量、条件判断、循环、过滤器等。 fr…

探索 Copilot:开启智能助手新时代

探索 Copilot&#xff1a;开启智能助手新时代 在当今数字化飞速发展的时代&#xff0c;人工智能&#xff08;AI&#xff09;正以前所未有的速度改变着我们的工作和生活方式。而 Copilot 作为一款强大的 AI 助手&#xff0c;凭借其多样的功能和高效的应用&#xff0c;正在成为众…

设计转换Apache Hive的HQL语句为Snowflake SQL语句的Python程序方法

首先&#xff0c;根据以下各类HQL语句的基本实例和官方文档记录的这些命令语句各种参数设置&#xff0c;得到各种HQL语句的完整实例&#xff0c;然后在Snowflake的官方文档找到它们对应的Snowflake SQL语句&#xff0c;建立起对应的关系表。在这个过程中要注意HQL语句和Snowfla…

[权限提升] Windows 提权 维持 — 系统错误配置提权 - 注册表权限配置错误提权

关注这个专栏的其他相关笔记:[内网安全] 内网渗透 - 学习手册-CSDN博客 0x01:注册表权限配置错误提权原理 通常 Windows 中的服务都是以 System 权限运行的,而 Windows 的服务程序的启动路径又是存放在注册表中的,若注册表配置不当,导致低权限用户可以更改注册表项时,就…

《手札·开源篇》从开源到商业化:中小企业的低成本数字化转型路径——一位甲方信息化负责人与开源开发者的八年双重视角

在中小企业数字化转型的浪潮中&#xff0c;"低成本"与"可持续性"始终是悬在决策者头顶的双刃剑。作为曾操盘过30信息化项目、主导过开源ERP二次开发的信息化老兵&#xff0c;我试图通过"甲方信息化负责人"与"开源开发者"的双重身份&am…

力扣经典题目之14. 最长公共前缀

今天继续给大家分享一道力扣的做题心得今天这道题目是14. 最长公共前缀 - 力扣&#xff08;LeetCode&#xff09; 题目如下 1&#xff0c;题目分析 题目给出了一个字符串数组&#xff0c;我们需要找出这个数组中所有字符串元素的最长的公共前缀字符&#xff0c;公共前缀和即为…