LeetCode Hot100 53.最大子数组和

题目描述

给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。

子数组是数组中的一个连续部分。

53. 最大子数组和 - 力扣(LeetCode)

思路

动态规划,维护一个变量pre记录遍历数组到此刻时的最大子数组和,如果num+pre<num,那么从num重新开始一个子数组

考虑到子数组中可能有负数,初始化max=nums[0]

代码

java 复制代码
class Solution {
    public int maxSubArray(int[] nums) {
        int max=nums[0];
        int pre=0;
        for(int num:nums){
            pre=Math.max(num,pre+num);
            max=Math.max(max,pre);
        }
        return max;
    }
}
相关推荐
王老师青少年编程1 小时前
csp信奥赛C++之反素数
数据结构·c++·数学·算法·csp·信奥赛·反素数
Renhao-Wan1 小时前
Java 算法实践(七):动态规划
java·算法·动态规划
pursuit_csdn2 小时前
LeetCode 1461. Check If a String Contains All Binary Codes of Size K
算法·leetcode·职场和发展
Crazy________3 小时前
力扣113个mysql简单题解析(包含plus题目)
mysql·算法·leetcode·职场和发展
生成论实验室3 小时前
即事经智能:一种基于生成易算的通用智能新范式(书)
人工智能·神经网络·算法·架构·信息与通信
清风20223 小时前
vllm 采样调研
人工智能·算法·机器学习
初次攀爬者3 小时前
力扣解题-无重复字符的最长子串
后端·算法·leetcode
MekoLi293 小时前
生成式推荐系统:从“判别式匹配”到“生成式创造”的范式革命
后端·算法
SoulruiA3 小时前
超容易理解+模版套路解决LeetCode 前序+中序、中序+后序、前序+后序遍历构造树问题
java·算法·力扣