动态规划

1 动态规划介绍

1.1 什么是动态规划

动态规划就是一种用来解决最优化问题的算法思想。简单来说,动态规划将一个复杂的问题分解成若干个子问题,通过综合子问题的最优解来得到原问题的最优解。需要注意的是,动态规划会将每个求解的子问题的解都记录下来。这样当下次碰到同样的子问题的时候 ,直接使用之前记录的结果。而不是重复计算
按我的理解来说,动态规划就是 自底向上求解,而一般的递归是自顶向下求解。当我们使用自底向上求解的时候,我们解决问题的时间复杂度就可以转化为O(n),从而大大优化我们的算法。但是问题来了,我们如何自底向上求解呢,不要着急,我们先来了解动态规划的基本性质。

1.2 动态规划三个重要概念

1.边界
边界问题是动态规划很重要的一个问题,因为我们在进行N次循环迭代的时候,要先找出初始问题的最优解,这就是我们说到的边界问题。即求出F(1),F(2)等初始值的最优解,一般这些边界的解我们很容易就可以得到。当我们分析出边界的最优解时,就可以通过循环迭代来求出整个问题的最优解。
2.最优子结构
最优子结构就是我们分解的每个子问题的解。由于动态规划是自底向上求解,所以我们在迭代的开始,只需要找到初始的计算边界问题,求出F(1),F(2)最小子问题的最优解,然后试着去寻找规律。
3. 状态转移方程
状态转移方程是动态规划的核心,决定了问题的每一阶段和下一阶段的关系。我们在循环迭代的时候,其实每次迭代的核心逻辑就是使用状态转移方程寻找下一问题的最优解。

1.3 动态规划的适用场景

当我们遇到求什么最大值,最小值,最短路径等等类似问题的时候,我们就可以考虑是不是可以用动态规划的算法来解决问题。

2 动态规划解题思路

最大自序和

给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。
示例:
输入: [-2,1,-3,4,-1,2,1,-5,4],
输出: 6
解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。

拿到这道题,一看是求最大和,那就拿动态规划的方式来解决这道题吧。我们把动态规划的三大核心概念去分析这道题。
给定dp[]存储每个子问题的最优解,mums[]为给定的数组。
1.边界问题。
当给定的数组长度为0是,我们返回0.
2.最优子结构
本题是分析n数组的最大连续子数组的和,我们可以先求数组长度为1时的最优解,即F(1)的最优解。
F(1):只能取-2 ,所以F(1)的最优解为-2
F(2):1> -2+1 > -2, 所以F(2)的最优解为1
F(3):…
3.状态转移方程
F(n) = max(nums[n], nums[n] + F(n))
为什么状态转移方程是这样的呢。我们来分析一下。
首先题目要求的是 连续子数组,我们必须保证我们所取到的每一个子问题的最优子结构都是连续子数组。所以我们从F(2)开始只有两种选择。
1.只选择nums[2]
2.选择 nums[2] + F(1)
这样才能保证取到的数组是连续子数组,我们只需要去取这两个结果的最大值。

3 动态规划例题分析

最大子序和代码分析

  public int maxSubArray(int[] nums) {
        int maxSum = nums[0];                      //maxSum为最终结果
        int curSum = 0;                            //curSum为动态和数
        for (int i = 0; i < nums.length; i++) {
            if (curSum < 0) {  
//curSum<0,那么curSum没有利用价值了,直接至0;curSum>0,之后才有可能加出更大的和
                curSum = 0;
            }
            curSum += nums[i];
            if (curSum > maxSum) {
                maxSum = curSum;
            }
        }
        return maxSum;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值