美文网首页
LeetCode-53. 最大子序和

LeetCode-53. 最大子序和

作者: 傅晨明 | 来源:发表于2019-12-04 09:41 被阅读0次

53. 最大子序和

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

示例:

输入: [-2,1,-3,4,-1,2,1,-5,4],
输出: 6
解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。

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


  • 1-暴力:n^2
  • 2-DP:
    a.分治(子问题) max_sum(i) = Max(max_sum(i - 1), 0) + a[i]
    b.状态数组: f[i]
    c.DP方程:f[i] = Max(f[i - 1] , 0) + a[i]
  1. dp问题:
    dp公式:dp[i] = max(nums[i] , nums[i] + dp[i - 1])
    提取出nums[i] :dp[i] = max( 0 , dp[i - 1]) + nums[i]
    //nums[i - 1]代表dp[i - 1]
    nums[i] = max(0 , nums[i - 1]) + nums[i]

  2. 最大子序和 = 当前元素自身最大(负的),或者 包含之前(正的)后最大

参考:
https://leetcode-cn.com/problems/maximum-subarray/solution/javashi-xian-dong-tai-gui-hua-fang-fa-by-zhengzhon/

https://leetcode-cn.com/problems/maximum-subarray/solution/hua-jie-suan-fa-53-zui-da-zi-xu-he-by-guanpengchn/

    public int maxSubArray(int[] nums) {
        int[] dp = new int[nums.length]; // 存储以i为结尾的最大子序列和
        dp[0] = nums[0]; // 第0个元素最大序列和为nums[0]
        int maxSum = nums[0]; // 最大子序列和
        // 遍历整个素组,获取以i为结尾的最大子序列和
        // 当dp[i-1]>0时,dp[i]=nums[i]+dp[i-1]
        // 当dp[i-1]<=0时,dp[i]=nums[i]
        for (int i = 1; i < nums.length; i++) {
            if (dp[i - 1] > 0) {
                dp[i] = dp[i - 1] + nums[i];
            } else {
                dp[i] = nums[i];
            }
            // 每次比较dp[i]和maxSum取最大值
            maxSum = Math.max(maxSum, dp[i]);
        }
        return maxSum;
    }

简化if else 判断:

    public int maxSubArray(int[] nums) {
        int[] dp = new int[nums.length]; // 存储以i为结尾的最大子序列和
        dp[0] = nums[0]; // 第0个元素最大序列和为nums[0]
        int maxSum = nums[0]; // 最大子序列和
        // 遍历整个素组,获取以i为结尾的最大子序列和
        // 当dp[i-1]>0时,dp[i]=nums[i]+dp[i-1]
        // 当dp[i-1]<=0时,dp[i]=nums[i]
        for (int i = 1; i < nums.length; i++) {
            dp[i] = Math.max(0, dp[i - 1]) + nums[i];
//          if (dp[i - 1] > 0) {
//              dp[i] = dp[i - 1] + nums[i];
//          } else {
//              dp[i] = nums[i];
//          }
            // 每次比较dp[i]和maxSum取最大值
            maxSum = Math.max(maxSum, dp[i]);
        }
        return maxSum;
    }

不新增dp数组,直接使用nums数组

    public int maxSubArray(int[] nums) {
        int maxSum = nums[0]; // 最大子序列和
        for (int i = 1; i < nums.length; i++) {
            nums[i] = Math.max(0, nums[i - 1]) + nums[i];
            maxSum = Math.max(maxSum, nums[i]);
        }
        return maxSum;
    }

对于上面的代码,也可以使用lastSum来记录nums[i-1]为结尾的最大连续子序列和

    public int maxSubArray(int[] nums) {
        int maxSum = nums[0]; // 最大子序列和
        int lastSum = nums[0];//假设当前索引为i,则lastSum保存以nums[i-1]为结尾的最大连续子序列和
        // 遍历整个素组,获取以nums[i]为结尾的最大子序列和
        for (int i = 1; i < nums.length; i++) {
            lastSum = Math.max(0, lastSum) + nums[i];
            maxSum = Math.max(maxSum, lastSum); // 每次比较lastSum和maxSum取最大值
        }
        return maxSum;
    }

相关文章

  • LeetCode-53. 最大子序和

    53. 最大子序和 给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其...

  • LeetCode-53.最大子序和

    写在前沿:本文代码均使用C语言编写 Description:给定一个整数数组 nums ,找到一个具有最大和的连续...

  • leetcode-53.最大子序和

    最大子序和  1.题目:给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返...

  • Python LeetCode-53. 最大子序和(难度-简单)

    1.题目描述 给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和...

  • 最长连续子序和问题

    0X00 算法总结 最大子序和 53. 最大子序和 这是一道非常经典的 dp 问题, 以最大子序和的最后一个数字来...

  • 【5月】LeetCode:我怎么还是这么菜

    5.3 题目链接 53. 最大子序和 很喜欢的解法(DP) 官方解(分治) 参考题解:最大子序和 但是仔细观察「方...

  • 动态规划1

    53. 最大子序和 70, 爬楼梯

  • [Leetcode] 53. 最大子序和

    53. 最大子序和 来源: 53. 最大子序和 1. 题目描述 给定一个整数数组 nums ,找到一个具有最大和...

  • 最大子序和

    给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。 示例: 输...

  • 最大子序和

    给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。 示例: 输...

网友评论

      本文标题:LeetCode-53. 最大子序和

      本文链接:https://www.haomeiwen.com/subject/sqthgctx.html