LeetCode 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

思路:

本文采用贪心的思路来解。每次 为 count 加上 nums[i],sum 取历次 count 中的最大值,如果 count < 0,说明此时需要重置子序列,将 count 重置为 0。最后返回 sum 。

代码:

java 复制代码
class Solution {
    public int maxSubArray(int[] nums) {
        int count=0;
        int sum=Integer.MIN_VALUE;
        for(int i=0;i<nums.length;i++){
            count+=nums[i];
            sum = Math.max(sum,count);//最大子列和
            if(count<0){//子列和为负数,说明如果加上当前nums[i]无论如何都会让子列和降低
                count=0;
            }
        }
        return sum;
    }
}

参考:代码随想录

相关推荐
賬號封禁中miu1 分钟前
图论之最小生成树
java·数据结构·算法·图论
闻缺陷则喜何志丹1 分钟前
【图论 拓扑排序 贪心 临项交换】P5603 小 C 与桌游 题解|普及+
c++·算法·图论·贪心·拓扑排序·洛谷·临项交换
闻缺陷则喜何志丹2 分钟前
【图论 BFS染色 并集查找 】P3663 [USACO17FEB] Why Did the Cow Cross the Road III S|普及+
c++·算法·图论·染色法·宽度优先·并集查找
月明长歌3 分钟前
Java数据结构:PriorityQueue堆与优先级队列:从概念到手写大根堆
java·数据结构·python·leetcode·
青山如墨雨如画3 分钟前
【北邮-研-图论】网络最大流的标号算法V1.0
网络·算法·图论·北邮
chao1898443 分钟前
基于MATLAB实现NSGA-II算法
开发语言·算法·matlab
mmz12076 分钟前
差分数组(c++)
c++·算法
xu_yule9 分钟前
算法基础-图论基础
数据结构·c++·算法·图论·dfs·bfs·最小生成树
月明长歌14 分钟前
【码道初阶】LeetCode面试题 17.14 最小 K 个数:两种堆解法的“同题不同命”
算法·leetcode·职场和发展
程芯带你刷C语言简单算法题16 分钟前
Day33~实现一个算法来识别一个字符串。
c语言·算法·c