牛客网-子数组的最大累加和问题

该博客介绍了一个使用动态规划求解数组中最大子数组和的问题。代码实现中,通过维护一个dp数组记录以每个元素结尾的子数组最大和,并在遍历过程中不断更新结果,确保时间复杂度为O(n)且空间复杂度为O(1)。示例展示了对于给定数组[1,-2,3,5,-2,6,-1],最大子数组和为12。
摘要由CSDN通过智能技术生成

一、题目

题目描述
给定一个数组arr,返回子数组的最大累加和
例如,arr = [1, -2, 3, 5, -2, 6, -1],所有子数组中,[3, 5, -2, 6]可以累加出最大的和12,所以返回12.
题目保证没有全为负数的数据
[要求]
时间复杂度为O(n)O(n),空间复杂度为O(1)O(1)

示例1
输入

[1, -2, 3, 5, -2, 6, -1]

返回值

12

二、思路

1、动态规划,新建一个一维数组储存累加和,每次累加时判断前面累加和是否为负,如果为负及时丢掉前面的
2、注意第一个数,有可能第一个就是满足条件那个,因为for循环是从1开始的,所以会把第一个数漏掉

三、代码

 class Solution {
public:
    /**
     * max sum of the subarray
     * @param arr int整型vector the array
     * @return int整型
     */
    int maxsumofSubarray(vector<int>& arr) {
        // write code here
        //dp[i]代表到第i位的时侯,以arr[i]结尾的连续子数组最大累加和
        int dp[arr.size()];//开辟dp
        dp[0] = arr[0];//初始化
        int res = arr[0];//保存最终的结果
        for(int i = 1;i < arr.size();i ++){
            dp[i] = max(arr[i],dp[i-1] + arr[i]);//维护dp[i]
            res = max(res,dp[i]);//每更新一个dp值就更新一下res
        }
        return res;
    }
};

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值