【Golang】LeetCode 53. 最大子数组和

53. 最大子数组和

题目描述

思路

我们只需设置两个变量来分别记录答案和当前子数组可能的最大和即可解决问题。

具体来说,我们设置ans, curr = nums[0], nums[0],随后开始对nums进行遍历。

由于数组当中可能会出现负数,我们使用curr来对数组和的中间状态进行记录,当curr + nums[i] < nums[i]时,说明当前的子数组和已经比当前数值更小了,此时我们重新开始统计子数组和,令curr = nums[i]

每一次遍历时,令ans = max(ans, curr),最终得到的即是答案。

基于以上思路,我们写代码来解决问题。

Golang 题解

go 复制代码
func maxSubArray(nums []int) int {
    ans, curr, n := nums[0], nums[0], len(nums)
    for i := 1; i < n; i ++ {
        if curr + nums[i] < nums[i] {
            curr = nums[i]
        } else {
            curr += nums[i]
        }
        ans = max(ans, curr)
    }
    return ans
}

Python 题解

python 复制代码
class Solution:
    def maxSubArray(self, nums: List[int]) -> int:
        ans, curr, n = nums[0], nums[0], len(nums)
        for i in range(1, n):
            if curr + nums[i] < nums[i]:
                curr = nums[i]
            else:
                curr += nums[i]
            ans = max(ans, curr)
        return ans
相关推荐
踩坑记录2 小时前
leetcode hot100 236.二叉树的最近公共祖先 medium dfs 递归
leetcode·深度优先
烟花落o2 小时前
【数据结构系列01】时间复杂度和空间复杂度:消失的数字
数据结构·算法·leetcode·刷题
努力学算法的蒟蒻2 小时前
day86(2.15)——leetcode面试经典150
数据结构·leetcode·面试
识君啊2 小时前
Java双指针 - 附LeetCode 经典题解
java·算法·leetcode·java基础·双指针
YGGP3 小时前
【Golang】LeetCode 189. 轮转数组
开发语言·leetcode·golang
Tisfy3 小时前
LeetCode 3379.转换数组:下标取模
算法·leetcode·题解·模拟·取模
骇城迷影3 小时前
代码随想录:数组篇
算法·leetcode
YGGP3 小时前
【Golang】LeetCode 56. 合并区间
算法·leetcode·职场和发展
We་ct4 小时前
LeetCode 61. 旋转链表:题解+思路拆解
前端·算法·leetcode·链表·typescript