【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
相关推荐
AlenTech23 分钟前
139. 单词拆分 - 力扣(LeetCode)
算法·leetcode·职场和发展
穿条秋裤到处跑2 小时前
每日一道leetcode(2026.03.30):判断通过操作能否让字符串相等 II
算法·leetcode
Q741_1472 小时前
每日一题 力扣 2840. 判断通过操作能否让字符串相等 II 力扣 2839. 判断通过操作能否让字符串相等 I 找规律 字符串 C++ 题解
c++·算法·leetcode·力扣·数组·找规律
我真不是小鱼2 小时前
cpp刷题打卡记录24——路径总和 & 路径总和II
数据结构·c++·算法·leetcode
nianniannnn2 小时前
力扣 347. 前 K 个高频元素
c++·算法·leetcode
x_xbx2 小时前
LeetCode:217. 存在重复元素
数据结构·leetcode·哈希算法
Frostnova丶2 小时前
LeetCode 2839. 判断通过操作能否让字符串相等 I
算法·leetcode
副露のmagic4 小时前
链表章节 leetcode 思路&实现
数据结构·leetcode·链表
Trouvaille ~5 小时前
【优选算法篇】拓扑排序——逻辑先后与任务依赖的终极拆解
数据结构·c++·算法·leetcode·青少年编程·蓝桥杯·拓扑学
XiYang-DING5 小时前
【LeetCode】118.杨辉三角
算法·leetcode·职场和发展