最大子序和 --动态规划

前面写了一些算法题,但是写到后面,发现不怎么系统起来,所以从这一篇开始,我们先着重介绍一下动态规划算法!

我们以题目开门见山.

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

示例:

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

解法一:动态规划思想

思路

  • 首先对数组进行遍历,当前最大连续子序列和为sum,结果为results
  • 如果sum > 0,则说明sum对结果有增益效果,则sum保留并加上当前遍历数字
  • 如果sum <= 0,则说明sum对结果无增益效果,需要舍弃,则sum直接更新为当前遍历数字
  • 每次比较sum 和 results的大小,将最大值置为results,遍历结束后返回结果results
  • 时间复杂度为O(n)

代码swift

func maxSubArray(_ nums: [Int]) -> Int {
    var results: Int = nums[0]
    var sum = 0
    for i in 0..<nums.count {
        if sum > 0 {
            sum = sum + nums[i]
        } else {
            sum = nums[i]
        }
        results = sum > results ? sum : results
    }
    return results
}

运行结果如下:

解法二:动态规划思想

思路

动态规划,用dp[i]表示以i结尾的最大子序列和。初始化值dp[0] = nums[0],然后从第二个数开始遍历

  • 如果当前数加上前一个最大序列和大于当前数,则将当前数加到序列和中,nums[i] + dp[i - 1] > nums[i],则dp[i] = nums[i] + dp[i - 1];
  • 反之以当前数结尾的最大序列和即为dp[i] = nums[i -1]

然后判断以当前结尾的最大序列和是否大于最大序列和。

时间复杂度为O(n)

空间复杂度为O(n)

代码

func maxSubArray(_ nums: [Int]) -> Int {
    guard nums.count > 0 else {return -1}
    var results: Int = nums[0]
    var dp = [Int]()
    dp.append(nums[0])
    for i in 1..<nums.count {
        if nums[i] + dp[i - 1] >= nums[i] {
            dp.append(nums[i] + dp[i - 1])
        } else {
            dp.append(nums[i])
        }
        if dp[i] > results {
            results = dp[i]
        }
    }
    return results
}

记住swift中不能直接用“=”赋值,用append增加元素

以上就是动态规划的思想和代码,大家可以写下,希望对大家有所帮助!!!当讲到分治思想,再会增加分治思想解决问题!

原文地址:https://www.cnblogs.com/guohai-stronger/p/11794415.html

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

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

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个数字组合所能得到的最大值,这样决策方式就是三

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

给定一个整数数组 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

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

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 单调队列维护的是前

TYVJ1305 最大子序和

P1305 最大子序和 时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 输入一个长度为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 备注 数据范围:10

AcWing:135. 最大子序和(前缀和 + 单调队列)

输入一个长度为n的整数序列,从中找出一段长度不超过m的连续子序列,使得子序列中所有数的和最大. 输入格式 第一行输入两个整数n,m. 第二行输入n个数,代表长度为n的整数序列. 同一行数之间用空格隔开. 输出格式 输出一个整数,代表该序列的最大子序和. 数据范围 1≤n,m≤3000001≤n,m≤300000 输入样例: 6 4 1 -3 5 1 -2 3 输出样例: 7 算法:前缀和 + 单调队列 注意:单调队列需要使用双端队列deque,因为其中需要头部弹出以及尾部弹出. #include

【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