leetcode 最大子序和 动态规划

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

示例:

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

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/maximum-subarray

思路:典型的动态规划问题,但是第一次思考错了,第一次是用f[i]表示前i个数字组合所能得到的最大值,这样决策方式就是三种,最后发现这种并没有满足连续的条件;正确的应该是f[i]表示以第I个数结尾的最大值,这样决策方式只有两种。

错误做法

class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        if(!nums.size())return 0;
        vector<int> f(nums.size());
        //base case
        f[0]=nums[0];
        //dp
        for(int j=1;j<nums.size();++j){
            f[j]=max(nums[j],max(f[j-1],f[j-1]+nums[j]));
            cout<<f[j]<<endl;
        }
        return f[nums.size()-1];
    }
};

正确做法

class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        if(!nums.size())return 0;
        //f[i]表示以第i个数结尾的所有连续数组的最大值
        vector<int> f(nums.size());
        //base case
        f[0]=nums[0];
        //dp
        int ans=f[0];
        for(int i=1;i<nums.size();++i)
            f[i]=max(f[i-1]+nums[i],nums[i]),ans=max(ans,f[i]);

        return ans;
    }
};

原文地址:https://www.cnblogs.com/clear-love/p/11371370.html

时间: 2024-07-30 09:17:40

leetcode 最大子序和 动态规划的相关文章

最大子序和 --动态规划

前面写了一些算法题,但是写到后面,发现不怎么系统起来,所以从这一篇开始,我们先着重介绍一下动态规划算法! 我们以题目开门见山. 给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和. 示例: 输入: [-2,1,-3,4,-1,2,1,-5,4], 输出: 6 解释: 连续子数组 [4,-1,2,1] 的和最大,为 6. 解法一:动态规划思想 思路 首先对数组进行遍历,当前最大连续子序列和为sum,结果为results 如果sum > 0,则说明s

Leetcode 最大子序和

这道题目是紫书上的经典题目,位于分治那一部分前后,再做这题依然觉得很巧妙. 分析:1.要明白的是,使用的是连续的一段,如果我统计i到j的和为负数,那肯定要舍去,因为他会对后面的答案有负面的作用,还不如不买,也就是将当前统计的区间和归零. 2.我们确实会遇到中间连续的一段可能存在负数,区间的和下降的情况.但是只要他还是大于0即可,我们每次加上一个数,区间的和仍然大于0,则和答案比较一下看谁大,如果比答案大则更新一下. 3.上面两种情况一直建立在和大于0的情况,极端情况下如果全部都小于0呢?题目要求

Leetcode之动态规划(DP)专题-53. 最大子序和(Maximum Subarray)

给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和. 示例: 输入: [-2,1,-3,4,-1,2,1,-5,4], 输出: 6 解释: 连续子数组 [4,-1,2,1] 的和最大,为 6. 进阶: 如果你已经实现复杂度为 O(n) 的解法,尝试使用更为精妙的分治法求解. 定义:dp[i] 表示从起点到index=i的这个段内的最大子序和. 例如:dp[1] = 在[-2,1]这个区间里面的最大子序和,dp[1]=1 写出状态转移方程:dp[i

LeetCode 第53题,最大子序和

题目概述 题目:力扣:53.最大子序和 难易:简单 内容: 给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和. 示例: 输入: [-2,1,-3,4,-1,2,1,-5,4] 输出: 6 解释: 连续子数组 [4,-1,2,1] 的和最大,为 6. 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/maximum-subarray 第一次思路 首先将数组类型分为三类:1.空数组 2.只有一个

【Leetcode】最大子序和

思路: 分治法.记最大子序和为maxResult,函数为int getMaxSub( *, * ) {}. 向量A= [a1, a2, a3, ...., ai, ai+1, a+2, ......, aj-1, aj], maxResult = max( maxresult(a1, ......, ai),  getMaxSub(*, i+1) ),其中sum(a1, ......, ai) <= 0. class Solution { public: int maxSubArray(vect

leetcode53. 最大子序和 &#127775;

题目: 给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和. 示例: 输入: [-2,1,-3,4,-1,2,1,-5,4], 输出: 6 解释: 连续子数组 [4,-1,2,1] 的和最大,为 6.进阶: 如果你已经实现复杂度为 O(n) 的解法,尝试使用更为精妙的分治法求解. 来源:力扣(LeetCode) 解答: leetcode优秀方案(来自力扣答案统计页,没有明确作者是谁,可留言告知): 1 class Solution: 2 "&qu

leetCode-最大子序和53

给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和. 示例: 输入: [-2,1,-3,4,-1,2,1,-5,4], 输出: 6 解释: 连续子数组 [4,-1,2,1] 的和最大,为 6 进阶: 如果你已经实现复杂度为 O(n) 的解法,尝试使用更为精妙的分治法求解. ==========================方案=========================== 1 /** 2 * 53.Maximum Subarray(最大

代码题(25)— 最大子序和、最长上升子序列

1.53. 最大子序和 给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和. 示例: 输入: [-2,1,-3,4,-1,2,1,-5,4], 输出: 6 解释: 连续子数组 [4,-1,2,1] 的和最大,为 6. class Solution { public: int maxSubArray(vector<int>& nums) { if(nums.empty()) return 0; int res = nums[0]; int

Tyvj1305最大子序和(单调队列优化dp)

描述 输入一个长度为n的整数序列,从中找出一段不超过M的连续子序列,使得整个序列的和最大. 例如 1,-3,5,1,-2,3 当m=4时,S=5+1-2+3=7当m=2或m=3时,S=5+1=6 输入格式 第一行两个数n,m第二行有n个数,要求在n个数找到最大子序和 输出格式 一个数,数出他们的最大子序和 测试样例1 输入 6 4 1 -3 5 1 -2 3 输出 7 备注 数据范围:100%满足n,m<=300000 是不超过m,不是选m个!!!!! /* 单调队列优化dp 单调队列维护的是前