剑指Offer 42:连续子数组的最大和

链接
题目:
在这里插入图片描述

思路:动态规划

模板:
在这里插入图片描述

既然是连续子数组,如果我们拿到了当前(0 ~ k-1)的和,对于后面一个(k)即将加入的元素,
如果加上他这一串会变得更大,我们肯定会加上它,如果它自己会比加上前面这一串更大,说明从它自己开始连续子数组的和可能会更大。

dp 数组的定义:以nums[i] 为结尾的「最大子数组和」为 dp[i] ;

按照数学归纳法,假设我们知道了 dp[i-1],如何推导出 dp[i] ?
dp[i] 有两种「选择」:
①要么与前⾯的相邻子数组连接,形成⼀个和更⼤的子数组;
②要么不与前⾯的子数组 连接,⾃成⼀派,⾃⼰作为⼀个子数组。

在这里插入图片描述

class Solution {
    public int maxSubArray(int[] nums) {
        // dp数组定义: 当前元素为结尾的最大子数组和
        int[] dp=new int[nums.length];
        Arrays.fill(dp,Integer.MIN_VALUE); // 找大,初始化为小
        //  base case
        dp[0]=nums[0];
        for(int i=1;i<nums.length;i++){ // 遍历所有状态
                dp[i]=Math.max(nums[i] , dp[i-1]+nums[i]); // 子数组连续 !
        }
        int res=Integer.MIN_VALUE;
        for(int i=0;i<nums.length;i++){
                res=Math.max(res,dp[i]);
        }
        return res;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值