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;
}
相关推荐
木子墨5164 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性
数据结构·c++·算法·leetcode
故事和你919 小时前
洛谷-算法1-7-搜索3
数据结构·c++·算法·leetcode·动态规划
y = xⁿ11 小时前
20天速通LeetCode day07:前缀和
数据结构·算法·leetcode
小雅痞11 小时前
[Java][Leetcode hard] 42. 接雨水
java·开发语言·leetcode
北顾笙98013 小时前
day26-数据结构力扣
数据结构·算法·leetcode
故事和你9114 小时前
洛谷-数据结构1-2-二叉树1
开发语言·数据结构·c++·算法·leetcode·动态规划·图论
_日拱一卒14 小时前
LeetCode:19删除链表的倒数第N个节点
算法·leetcode·链表
y = xⁿ14 小时前
20天速通LeetCode day08:关于栈
算法·leetcode·职场和发展
XWalnut15 小时前
LeetCode刷题 day13
数据结构·算法·leetcode
im_AMBER16 小时前
Leetcode 158 数组中的第K个最大元素 | 查找和最小的 K 对数字
javascript·数据结构·算法·leetcode·