力扣hot100:最大子数组和

题目描述:

思路分析:

运用动态规划的思想,设动态规划列表 dp ,dp[i] 代表以元素 nums[i] 为结尾的连续子数组最大和。从第二个元素开始遍历原数组,如果dp[i-1]是大于0的,就说明当前元素加上之前的最大字数组和会更大,故dp[i]=dp[i-1]+nums[i],如果dp[i-1]是小与0的,说明此时以nums[i]结尾的最大字数组为dp[i]=nums[i],最后遍历dp数组就会的解。

代码:

java 复制代码
class Solution {
    public int maxSubArray(int[] nums) {
        int n=nums.length;
        int dp[] =new int[n];
        dp[0]=nums[0];
        for(int i=1;i<n;i++){
            if(dp[i-1]>0){
                dp[i]=dp[i-1]+nums[i];
            }else{
                dp[i]=nums[i];
            }
        }
        int ans=-10000;
        for(int i=0;i<n;i++){
            ans=Math.max(dp[i],ans);
        }
        return ans;
    }
}
相关推荐
我是咸鱼不闲呀3 分钟前
力扣Hot100系列21(Java)——[多维动态规划]总结(不同路径,最小路径和,最长回文子串,最长公共子序列, 编辑距离)
java·leetcode·动态规划
lihao lihao6 分钟前
二分查找
java·数据结构·算法
WolfGang0073219 分钟前
代码随想录算法训练营 Day15 | 二叉树 part05
数据结构·算法
sheeta19989 分钟前
LeetCode 每日一题笔记 2025.03.20 3567.子矩阵的最小绝对差
笔记·leetcode·矩阵
代码栈上的思考9 分钟前
消息队列持久化:文件存储设计与实现全解析
java·前端·算法
qq_4176950519 分钟前
内存对齐与缓存友好设计
开发语言·c++·算法
2301_8166512220 分钟前
实时系统下的C++编程
开发语言·c++·算法
2401_8318249621 分钟前
C++与Python混合编程实战
开发语言·c++·算法
2301_8166512228 分钟前
C++中的策略模式高级应用
开发语言·c++·算法