力扣每日一题53:最大子数组和

题目描述:

给你一个整数数组 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

进阶: 如果你已经实现复杂度为 O(n) 的解法,尝试使用更为精妙的 分治法 求解。

通过次数

1.5M

提交次数

2.8M

通过率

54.9%

思路和题解:(在线处理)

当一个子列的和sum加上后一项a[i]时,只有当sum>0时,后一项加上sum才能增大,才有扩大子列的可能。当sum小于零时,至少它不会将包含后一项a[i]的子序列的和增大,所以我们就直接舍弃。先让max设置为nums[i]的最小值-10^4,sum的初值为零。遍历一次nums数组,每次sum+=mus[i],如果sum<0,就令sum=0,如果sum>max,就令max=sum。最后返回sum。

代码:

复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        int sum=0;
        int max=-10009;
        for(int i=0;i<nums.size();i++)
        {
            sum+=nums[i];
            if(sum>max)
            {
                max=sum;
            }
            if(sum<0)
            {
                sum=0;
            }
        }
        return max;
    }
};
相关推荐
AI科技星10 小时前
算法联盟·全域数学公理体系下黑洞标量毛发与LVK引力波O4全维理论、求导、证明、计算、验证、分析
人工智能·线性代数·算法·架构·学习方法·量子计算
谙弆悕博士10 小时前
【附C语言源码】C语言 栈结构 实现及其扩展操作
c语言·开发语言·数据结构·算法·链表·指针·
YuanDaima204810 小时前
图论基础原理与题目说明
数据结构·人工智能·python·算法·图论·手撕代码
AI人工智能+电脑小能手10 小时前
【大白话说Java面试题 第53题】【JVM篇】第13题:JVM采用什么算法判断一个对象是否需要被回收?
java·jvm·算法·面试
z2005093010 小时前
今日算法(二叉树)
数据结构
小赵不会秃头10 小时前
数据结构Day 06:线性结构、库操作及 Makefile 完整学习笔记
java·linux·数据结构·算法·面试
Shan120511 小时前
在C++中尝试封装为函数
开发语言·c++·算法
郝学胜-神的一滴11 小时前
干货版《算法导论》04:渐近复杂度与序列接口实战
java·开发语言·数据结构·c++·python·算法
zzzsde11 小时前
【Linux】信号处理(3)信号处理&&valatile关键字
linux·运维·服务器·开发语言·算法
curry____30311 小时前
二叉树的前序中序遍历以及用前序和中序求解树
数据结构