【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 小时前
力扣:19.删除链表的倒数第 N 个结点
算法·leetcode·链表
叶小鸡7 小时前
小鸡玩算法-力扣HOT100-堆
数据结构·算法·leetcode
小雅痞7 小时前
[Java][Leetcode simple] 28. 找出字符串中第一个匹配项的下标
java·开发语言·leetcode
khalil10208 小时前
代码随想录算法训练营Day-31贪心算法 | 56. 合并区间、738. 单调递增的数字、968. 监控二叉树
数据结构·c++·算法·leetcode·贪心算法·二叉树·递归
im_AMBER12 小时前
Leetcode 160 最小覆盖子串 | 串联所有单词的子串
开发语言·javascript·数据结构·算法·leetcode
帅小伙―苏13 小时前
力扣483找到字符串中所有字母异位词
算法·leetcode
smj2302_7968265214 小时前
解决leetcode第3906题统计网格路径中好整数的数目
python·算法·leetcode
KobeSacre14 小时前
leetcode 树
算法·leetcode·职场和发展
大大杰哥15 小时前
leetcode hot100(1) 哈希
leetcode
Engineer邓祥浩15 小时前
LeetCode 热题 100 - 第1题:两数之和
算法·leetcode·职场和发展