LeetCode 刷题【53. 最大子数组和】

53. 最大子数组和

自己做

解:滑动数组

cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        int begin = 0;
        int end = (int)nums.size() - 1;
        int sum = 0;
        int max = nums[0];

        //剔除左边小于0的部分
        int left_count = 0;
        for(int i = 0; i < (int)nums.size(); i++){
            left_count += nums[i];

            if(left_count > max)   //记录下前面的最大值,可能会出现前面全为正,后面一个很大负数的情况,这样就会造成丢失,这里记录下来
                max = left_count;

            if(left_count < 0){         //找到了负值的部分,更新边界
                begin = i + 1;
                left_count = 0;         //重置计数
            }

        }

        //剔除右边小于0的部分
        int right_count = 0;
        for(int i = (int)nums.size() - 1; i > begin; i--){
            right_count += nums[i];

            if(right_count < 0){         //找到了负值的部分,更新边界
                end = i - 1;
                right_count = 0;         //重置计数
            }
        }

        //情况:如果数组中的元素全是负的(或者相加都为负,或者前面的最大子数组和都比后面找到的大),这里返回其中的最大值
        if(begin >= end || max > sum)
            return max;


        //经过上面处理后得到对应子数组,现在遍历子数组统计
        for(int i = begin; i <= end; i++)
            sum += nums[i];

        return sum;
    }
};
相关推荐
CoderCodingNo1 分钟前
【GESP】C++五级练习题 luogu-P1865 A % B Problem
开发语言·c++·算法
大闲在人12 分钟前
7. 供应链与制造过程术语:“周期时间”
算法·供应链管理·智能制造·工业工程
小熳芋15 分钟前
443. 压缩字符串-python-双指针
算法
Charlie_lll25 分钟前
力扣解题-移动零
后端·算法·leetcode
chaser&upper25 分钟前
矩阵革命:在 AtomGit 解码 CANN ops-nn 如何构建 AIGC 的“线性基石”
程序人生·算法
weixin_4997715534 分钟前
C++中的组合模式
开发语言·c++·算法
iAkuya1 小时前
(leetcode)力扣100 62N皇后问题 (普通回溯(使用set存储),位运算回溯)
算法·leetcode·职场和发展
近津薪荼1 小时前
dfs专题5——(二叉搜索树中第 K 小的元素)
c++·学习·算法·深度优先
xiaoye-duck1 小时前
吃透 C++ STL list:从基础使用到特性对比,解锁链表容器高效用法
c++·算法·stl
松☆1 小时前
CANN与大模型推理:在边缘端高效运行7B参数语言模型的实践指南
人工智能·算法·语言模型