【每日一题】LeetCode 53. 最大子数组和 TypeScript

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

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

示例 1:

复制代码
输入:nums = [-2,1,-3,4,-1,2,1,-5,4]
输出:6
解释:连续子数组 [4,-1,2,1] 的和最大,为 6 。

示例 2:

复制代码
输入:nums = [1]
输出:1

示例 3:

复制代码
输入:nums = [5,4,-1,7,8]
输出:23

提示:

  • 1 <= nums.length <= 105
  • -104 <= nums[i] <= 104

TypeScript 复制代码
function maxSubArray(nums: number[]): number {
    let pre =nums[0]
    let res = nums[0]
    for(let i=1;i<nums.length;i++){
        pre = Math.max(nums[i],pre+nums[i])
        res = Math.max(res,pre)
    }
    return res
};

这个为什么不用forEach,因为先初始化了nums0,下标0不参与比较。forEach是从0开始遍历整个数组

TypeScript 复制代码
function maxSubArray(nums: number[]): number {
    //从第一个开始,最大是第一个
    let pre =nums[0]
    let res = nums[0]
    //从第二个数开始遍历
    for(let i=1;i<nums.length;i++){
        //比较当前的数和之前的数的和
        //如果当前的数比以前的数大,这时候从当前数开始算
        pre = Math.max(nums[i],pre+nums[i])
        res = Math.max(res,pre)
    }
    return res
};

共勉

相关推荐
旖-旎1 小时前
FloodFill(图像渲染)(1)
c++·算法·深度优先·力扣
戴西软件2 小时前
戴西 DLM 许可授权管理系统:破解无网络环境下工业软件授权难题,助力制造企业降本增效
网络·人工智能·python·深度学习·程序人生·算法·制造
2601_961875242 小时前
法考资料2026|全套|资料已整理
数据结构·算法·链表·贪心算法·eclipse·线性回归·动态规划
无限码力2 小时前
美团研发岗 4月18号笔试真题 - 坐标
算法·美团笔试真题·美团笔试题·美团研发岗笔试题·美团研发岗4月18号真题
有点。3 小时前
C++倍增法(练习题)
c++·算法
智者知已应修善业4 小时前
【51单片机8位数码管同时倒计时从9999】2024-1-25
c++·经验分享·笔记·算法·51单片机
洛水水4 小时前
【力扣100题】86.柱状图中最大的矩形
算法·leetcode·职场和发展
渡之4 小时前
GRiM-Net 深度解析 | 无人机 GNSS 拒止场景下两阶段跨视角视觉定位框架
深度学习·算法·动态规划·无人机