day26 求一段连续子数组之和的最大值

题目描述

方法一:超出时间限制

思路:选一个起点,选一个终点,计算起点到终点的和;求max;

起点几种可能:0 到 size -1;

终点: 起点 到 size -1;

c 复制代码
int maxSubArray(int* nums, int numsSize){
    int maxSum, tempSum, i, j, k;
    maxSum = -101;
    for(i = 0;  i < numsSize; i++){
        for(j = i; j < numsSize; j++){
            tempSum = 0;
            for(k = i; k <= j; k++){
                tempSum += nums[k];
            } 
            if(tempSum > maxSum)
                maxSum = tempSum;
        }
    }
    return maxSum;
}

方法二:贪心算法

依次遍历数组的每个元素,并记录前面i - 1个元素的最大和preSum,若preSum < 0, 则从当前元素重新开始计算;若 preSum > 0,则当前最大和为preSum + nums[i]。

c 复制代码
int maxSubArray(int* nums, int numsSize){
    if((nums == NULL) || (numsSize == 0))
        return 0;

    int maxRes = nums[0];
    int preSum = nums[0];

    for (int i = 1; i < numsSize; i++)
    {
        if (preSum < 0) {
            preSum = nums[i];
        } else {
            preSum += nums[i];
        }
        if (preSum > maxRes){
            maxRes = preSum;
        }     
    }
    return maxRes;
}
c 复制代码
int maxSubArray(int* nums, int numsSize){
   int result = INT_MIN;
   int count = 0;
   for (int i = 0;i < numsSize;i++){
       count += nums[i];
       if (count > result) {
           result = count;
       }

       if (count < 0) {
           count = 0;
       }
   }
   return result;
}
相关推荐
Swift社区几秒前
LeetCode 456 - 132 模式
java·算法·leetcode
LYFlied1 分钟前
【每日算法】LeetCode 152. 乘积最大子数组(动态规划)
前端·算法·leetcode·动态规划
圣保罗的大教堂5 分钟前
leetcode 3075. 幸福值最大化的选择方案 中等
leetcode
爱学大树锯14 分钟前
【(格式化字符串)】
算法
wearegogog12315 分钟前
压缩感知和稀疏表示恢复算法中的L1同伦算法
人工智能·算法
core51220 分钟前
决策树 (Decision Tree):像“猜猜看”游戏一样的AI算法
人工智能·算法·决策树
夏乌_Wx28 分钟前
练题100天——DAY34:错误的集合+图片平滑器+最长连续递增序列
数据结构
xa1385086939 分钟前
ARCGIS PRO SDK 多边形四至点计算
算法·arcgis
Dream it possible!1 小时前
LeetCode 面试经典 150_回溯_单词搜索(104_79_C++_中等)
c++·leetcode·面试·回溯
AuroraWanderll1 小时前
类和对象(四):默认成员函数详解与运算符重载(下)
c语言·数据结构·c++·算法·stl