动态规划之最大子数组和问题

一.题目解析

题目本身很容易看明白,简单来说就是求最大值,求什么最大值呢?求子数组的最大值

二.讲解算法原理

1.状态表示

我们以往的状态表示就是根据两点1.经验,2题目要求

我们通常以一个位置结尾来研究问题,所以,这次我们还是这样做。

创建一个dp表,dp[i]表示以i位置为结尾的子数组的最大值。

2.状态转移方程

如图所示,假设i就在此位置,在所有的子数组中,大概分为两类,一种是长度大于1,一种是长度为1。

所以,仔细观察,我们不难发现

3.初始化

我们看,当i=0时,i-1=-1,就会越界,没法整,所以我们可以先将nums[0]初始化出来。

4.填表顺序

由大到小依次填表

5.返回值

返回dp[i]。

三.代码实现

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值