【每天学习一点算法 2025/12/30】最大子序和

每天学习一点算法 2025/12/30

题目:最大子序和

给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。

子数组 是数组中的一个连续部分。

依旧是动态规划的题哈,我们分析一下,我们如果能计算出每一个位置的连续子数组最大和,用数组存储起来,最后返回数组中最大的值是不是就是我们要求得的结果,那计算每一个位置的连续子数组最大和呢?

  • 第 1 个位置:肯定就是这个元素的值了, arr[0] = nums[0]
  • 第 2 个位置:要么是上一个元素的值加上当前位置的元素值,要么就是当前元素值, Math.max(arr[0], nums[1])
  • 第 n 个位置:从第 2 个位置的分析情况就能得出了, Math.max(arr[n - 1], nums[n])
typescript 复制代码
function maxSubArray(nums: number[]): number {
  let arr = [nums[0]] // 数组用于存放每个位置最大和的连续子数组的最大和
  // 循环计算
  for (let i = 1; i < nums.length; i++) {
    arr.push(Math.max(arr[i - 1] + nums[i], nums[i]))
  }
  // 返回最大值结果
  return Math.max(...arr)
};

其实可以看出来我们每次循环只用到了上一次的最大值,所以我们只需要用一个变量存储最大值,另一个变量存储上一个位置的最大值即可。

typescript 复制代码
function maxSubArray(nums: number[]): number {
  let max = nums[0] // 用于存储上最大和
  let currentMax = nums[0] // 用于当前位置的最大和
  for (let i = 1; i < nums.length; i++) {
    currentMax = Math.max(currentMax + nums[i], nums[i]) // 计算当前位置最大和
    max = Math.max(max, currentMax) // 计算整体最大和
  }
  return max
};

题目来源:力扣(LeetCode)

相关推荐
美式请加冰几秒前
字符串的介绍和使用
算法
m0_733612216 分钟前
C++20概念(Concepts)入门指南
开发语言·c++·算法
仰泳的熊猫9 分钟前
题目2571:蓝桥杯2020年第十一届省赛真题-回文日期
数据结构·c++·算法·蓝桥杯
我喜欢就喜欢13 分钟前
基于离散余弦变换的感知哈希算法:原理、实现与工程实践
算法·哈希算法
2301_8073671935 分钟前
C++中的模板方法模式
开发语言·c++·算法
罗罗攀1 小时前
PyTorch学习笔记|张量的广播和科学运算
人工智能·pytorch·笔记·python·学习
PhotonixBay1 小时前
共聚焦显微镜的结构组成与应用
人工智能·算法·机器学习
CDA数据分析师干货分享1 小时前
汉江师范学院数据科学与大数据技术专业大二学生:CDA一级学习经验
大数据·经验分享·学习·数据分析·cda证书·cda数据分析师
SuniaWang1 小时前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题四:《Ollama 模型管理与调优:让 AI 模型在低配服务器上流畅运行》
人工智能·学习·spring
逆境不可逃1 小时前
LeetCode 热题 100 之 33. 搜索旋转排序数组 153. 寻找旋转排序数组中的最小值 4. 寻找两个正序数组的中位数
java·开发语言·数据结构·算法·leetcode·职场和发展