2024/4/2—力扣—连续数列

代码实现:

思路:最大子数组和

**解法一:**动态规划

cpp 复制代码
#define max(a, b) ((a) > (b) ? (a) : (b))

int maxSubArray(int* nums, int numsSize) {
    if (numsSize == 0) { // 特殊情况
        return 0;
    }
    int dp[numsSize];
    dp[0] = nums[0];
    int result = dp[0];
    for (int i = 1; i < numsSize; i++) {
        dp[i] = max(dp[i - 1] + nums[i], nums[i]); // 状态转移方程
        result = max(result, dp[i]); // result 保存dp[i]的最大值
    }
    return result;
}

**解法二:**贪心

cpp 复制代码
int maxSubArray(int *nums, int numsSize) {
    int result = INT32_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;
}
相关推荐
Storynone1 天前
【Day20】LeetCode:39. 组合总和,40. 组合总和II,131. 分割回文串
python·算法·leetcode
j_xxx404_1 天前
C++算法:前缀和与哈希表实战
数据结构·算法·leetcode
We་ct1 天前
LeetCode 22. 括号生成:DFS回溯解法详解
前端·数据结构·算法·leetcode·typescript·深度优先·回溯
Frostnova丶1 天前
LeetCode 3296. 使山区高度为零的最少秒数
算法·leetcode
样例过了就是过了1 天前
LeetCode热题100 全排列
数据结构·c++·算法·leetcode·dfs
程序员夏末1 天前
【LeetCode | 第六篇】算法笔记
笔记·算法·leetcode
滴滴答滴答答1 天前
机考刷题之 23&24&25 LeetCode 55&213&123
算法·leetcode·职场和发展
无限进步_1 天前
【C++】只出现一次的数字 III:位运算的巧妙应用
数据结构·c++·git·算法·leetcode·github·visual studio
一叶落4381 天前
LeetCode 74 | 搜索二维矩阵(C语言版题解)
c语言·数据结构·c++·算法·leetcode·矩阵·动态规划
iAkuya1 天前
(leetcode)力扣100 96.只出现一次的数字(位运算)
算法·leetcode·职场和发展