记录Leetcode第九天(53. Maximum Subarray)

记录Leetcode第九天(53. Maximum Subarray)

1. 题目

Given an integer array nums, find the contiguous subarray (containing at least one number) which has the largest sum and return its sum.

2. 例子

Input: [-2,1,-3,4,-1,2,1,-5,4],
Output: 6
Explanation: [4,-1,2,1] has the largest sum = 6.

3.分析

两种思路差不多,第二种更好理解。
假设代码分成两部分:判断首位代码部分和确定首位后比较最大值部分
先判断最终数组首位。累加数组里的值和小于0的话数组至此前面部分整个不要(第一种代码中sum=0,第二种代码中的dp=nums[i]),结合上面例子里面的话就是判断了数组[-2](舍弃),[1](保留),[1,-3](舍弃)。
从数组里第一个4开始往后,不会再出现累加数组小于零。(当然程序其实不知道以后会不会出现累加数组小于零,只是为了好分析)所以就一直累加数组值,每加一次就和设定的最大值(max,或者maxSum)比较。最后返回最大值。

好久不写代码傻掉了,所以思路错啦就没放自己写的代码。一直想着是比较由首尾两个正数组成的数组的大小,就写的很复杂。
想想以后要学集成电路了,不知道刷leetcode有没有用。。。

4.代码

第一个代码是gongxinheng大神的。

class Solution {
public:
    int maxSubArray(vector<int>& nums) {
         int sum = 0;
        int max = numeric_limits<int>::min();
        for(size_t i = 0; i < nums.size(); i++) {
            sum += nums[i];
            max = std::max(sum, max);
            sum = std::max(sum, 0);
        }
         return max;
    }
};

第二个代码是zefengsong大神的。

class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        int dp = nums[0];
        int maxSum = dp;
        for(int i = 1; i < nums.size(); i++){
            dp = max(dp + nums[i], nums[i]);
            maxSum = max(maxSum, dp);
        }
        return maxSum;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值