栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

53. 最大子数组和(Java) Leecode

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

53. 最大子数组和(Java) Leecode

解题思路:

动态规划问题,利用dp数组。

dp[ i ] 只与dp[i - 1] 有关。
所以要构建dp数组,再比大小。

这里有个优化方法,在构建dp数组的时候,就直接比较子数组大小。

class Solution {
    public int maxSubArray(int[] nums) {

        int n = nums.length;
        if(n == 0) return 0;

        //base case
        int dp_0 = nums[0];
        int dp_1;
        int res = dp_0; //记录子数组大小

        //在构建dp数组的时候,比较最大值
        for(int i = 1; i < n ; i++){
            dp_1 = Math.max(nums[i], nums[i] + dp_0);
            dp_0 = dp_1;
            res = Math.max(res, dp_1);
        }

        return res;
    }
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/771042.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号