news 2026/5/30 19:25:00

Leetcode 剑指 Offer II 161. 连续天数的最高销售额

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Leetcode 剑指 Offer II 161. 连续天数的最高销售额

题目难度: 简单

原题链接

今天继续更新 Leetcode 的剑指 Offer(专项突击版)系列, 大家在公众号算法精选里回复剑指offer2就能看到该系列当前连载的所有文章了, 记得关注哦~

题目描述

某公司每日销售额记于整数数组 sales,请返回所有 连续 一或多天销售额总和的最大值。

要求实现时间复杂度为 O(n) 的算法。

示例 1:

  • 输入:sales = [-2,1,-3,4,-1,2,1,-5,4]
  • 输出:6
  • 解释:[4,-1,2,1] 此连续四天的销售总额最高,为 6。

示例 2:

  • 输入:sales = [5,4,-1,7,8]
  • 输出:23
  • 解释:[5,4,-1,7,8] 此连续五天的销售总额最高,为 23。

提示:

  • 1 <= arr.length <= 10^5
  • -100 <= arr[i] <= 100

题目思考

  1. 如何记录最大和?
  2. 可以不使用额外空间吗?

解决方案

思路

  • 题目要求复杂度 O(N), 那么我们就不能使用暴力两重循环求当前前缀和的方法了, 那样的复杂度是 O(N^2)
  • 那如何做到一次遍历就计算出结果呢?
  • 假设当前以 i 结尾的最大和是 sm, 那么到 i+1 的时候, 以它结尾的最大和可以有两种选择:
    • 在 sm 的基础上加上 i+1 的值
    • 也可以另起炉灶, 从 i+1 开始计算 (对应的是sm < 0的情况)
  • 也即 i+1 结尾的最大和就是max(sm+arr[i+1], arr[i+1])
  • 它就是新的 sm 值, 这样就不需要额外的空间
  • 而最终的结果自然就是max(以各个下标结尾的最大和), 可以在遍历的时候顺带一起判断
  • 以上就是典型的动态规划的思想, 利用前面的计算结果来推导出当前的结果
  • 下面的代码对必要步骤有详细的解释, 方便大家理解

复杂度

  • 时间复杂度O(N)
    • 只需要遍历整个数组一遍
  • 空间复杂度O(1)
    • 不需要额外空间

代码

classSolution:defmaxSales(self,sales:List[int])->int:# 初始化最终结果为负无穷, 因为可能数组全部都是负数res=-float('inf')# 初始化和为0sm=0forxinsales:# 计算当前结尾的最大值sm=max(sm+x,x)# 更新最终结果为当前最大的最大值res=max(res,sm)returnres

大家可以在下面这些地方找到我~😊

我的 GitHub

我的 Leetcode

我的 CSDN

我的知乎专栏

我的头条号

我的牛客网博客

我的公众号: 算法精选, 欢迎大家扫码关注~😊

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/28 22:25:11

提升学术写作:6款AI工具助你高效完成论文

当前学术写作领域已出现一系列融合人工智能技术的创新工具&#xff0c;这些系统依托前沿的自然语言处理算法&#xff0c;能够高效完成论文框架自动构建、文本润色提升以及相似度检测等关键任务&#xff0c;特别适合研究生学位论文写作和学术材料整理等应用场景。值得注意的是&a…

作者头像 李华
网站建设 2026/5/30 12:16:29

你永远不知道用户会怎样使用你的软件

客户Day1:我们的资源全部放在文件夹A中你们拉下来解密就行了。 我:OK。 客户Day2:我们现在新加了一种资源放在文件夹B中你们需要把两个文件夹拉取下来展示在一个界面上。 我:OK我把资源拉取下来解密过后拼接一下展示在一个界面上。 客户Day3:软件怎么用不了。 我:一顿排查。。。…

作者头像 李华
网站建设 2026/5/28 12:56:41

小程序计算机毕设之基于springboot+小程序的桂林旅游桂林源记小程序的设计与实现基于SpringBoot与微信小程序的文化旅游小程序系统设计与实现(完整前后端代码+说明文档+LW,调试定制等)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/29 18:03:23

【计算机毕业设计案例】基于springboot+小程序的桂林旅游桂林源记小程序桂林旅游景点导游平台的设计与实现(程序+文档+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/28 13:37:09

小程序毕设选题推荐:基于springboot+小程序的校园点餐系统小程序的设计与实现基于springboot校园订餐小程序设计与实现【附源码、mysql、文档、调试+代码讲解+全bao等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/28 12:56:47

什么是网络安全(Cybersecurity)

文章目录 为什网络安全非常重要常见网络攻击有哪些网络安全有哪些类型 哪些领域网络安全如何工作、最佳实践网络安全挑战及趋势网络安全 vs. 信息安全 vs. 计算机安全 vs. IT安全相关方案及产品 不同组织机构对网络安全&#xff08;Cybersecurity或Cyber Security&#xff09;的…

作者头像 李华