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;
}
相关推荐
6Hzlia4 小时前
【Hot 100 刷题计划】 LeetCode 48. 旋转图像 | C++ 矩阵变换题解
c++·leetcode·矩阵
Morwit6 小时前
【力扣hot100】 1. 两数之和
数据结构·c++·算法·leetcode·职场和发展
py有趣6 小时前
力扣热门100题之岛屿的数量(DFS/BFS经典题)
leetcode·深度优先·宽度优先
qinian_ztc7 小时前
frida 14.2.18 安装报错解决
算法·leetcode·职场和发展
田梓燊9 小时前
2026/4/11 leetcode 3741
数据结构·算法·leetcode
小肝一下11 小时前
每日两道力扣,day8
c++·算法·leetcode·哈希算法·hot100
语戚12 小时前
力扣 51. N 皇后:基础回溯、布尔数组优化、位运算全解(Java 实现)
java·算法·leetcode·力扣·剪枝·回溯·位运算
py有趣13 小时前
力扣热门100题之螺旋矩阵
算法·leetcode
人道领域13 小时前
【LeetCode刷题日记】383 赎金信
算法·leetcode·职场和发展
旖-旎13 小时前
哈希表(存在重复元素)(3)
数据结构·c++·学习·算法·leetcode·散列表