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;
}
相关推荐
刚学HTML1 小时前
leetcode 05 回文字符串
算法·leetcode
Yan.love1 小时前
开发场景中Java 集合的最佳选择
java·数据结构·链表
AC使者1 小时前
#B1630. 数字走向4
算法
冠位观测者1 小时前
【Leetcode 每日一题】2545. 根据第 K 场考试的分数排序
数据结构·算法·leetcode
古希腊掌管学习的神2 小时前
[搜广推]王树森推荐系统笔记——曝光过滤 & Bloom Filter
算法·推荐算法
qystca2 小时前
洛谷 P1706 全排列问题 C语言
算法
古希腊掌管学习的神2 小时前
[LeetCode-Python版]相向双指针——611. 有效三角形的个数
开发语言·python·leetcode
浊酒南街2 小时前
决策树(理论知识1)
算法·决策树·机器学习
就爱学编程2 小时前
重生之我在异世界学编程之C语言小项目:通讯录
c语言·开发语言·数据结构·算法
学术头条3 小时前
清华、智谱团队:探索 RLHF 的 scaling laws
人工智能·深度学习·算法·机器学习·语言模型·计算语言学