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;
}
相关推荐
2013092416277 小时前
1968年 Hart, Nilsson, Raphael 《最小成本路径启发式确定的形式基础》A* 算法深度研究报告
人工智能·算法
如何原谅奋力过但无声8 小时前
【力扣-Python-滑动窗口经典题】567.字符串的排列 | 424.替换后的最长重复字符 | 76.最小覆盖子串
算法·leetcode
玄冥剑尊8 小时前
贪心算法进阶
算法·贪心算法
玄冥剑尊9 小时前
贪心算法深化 I
算法·贪心算法
52Hz1189 小时前
力扣73.矩阵置零、54.螺旋矩阵、48.旋转图像
python·算法·leetcode·矩阵
BHXDML9 小时前
第一章:线性回归& 逻辑回归
算法·逻辑回归·线性回归
iAkuya9 小时前
(leetcode)力扣100 二叉搜索树种第K小的元素(中序遍历||记录子树的节点数)
算法·leetcode·职场和发展
-To be number.wan10 小时前
B 树 vs B+ 树:为什么 MySQL 用 B+ 树,而不是 B 树?
数据结构
杨间10 小时前
《排序算法全解析:从基础到优化,一文吃透八大排序!》
c语言·数据结构·排序算法
Remember_99310 小时前
【LeetCode精选算法】滑动窗口专题二
java·开发语言·数据结构·算法·leetcode