力扣 最大子数组和

动态规划,前缀和,维护状态更新。

题目

从题可以看出,找的是最大和的连续子数组,即一个数组中的其中一个连续部分。从前往后遍历,每遍历到一个数可以尝试做叠加,注意是尝试,因为有可能会遇到一个很大的负数,把前面加起来的都抵消掉,显然不是所要的,因此在dp中需要一个做结果集的维护,与更新后的总数做比较,看看是否需要做更新。

java 复制代码
class Solution {
    public int maxSubArray(int[] nums) {
        int[] f = new int[nums.length];
        f[0] = nums[0];
        int ans = f[0];
        for (int i = 1; i < nums.length; i++) {
            f[i] = Math.max(f[i - 1], 0) + nums[i];
            ans = Math.max(ans, f[i]);
        }
        return ans;
    }
}

然后这里用类似滚动数组的思想做优化,可以少用一个数组做空间复杂度上的优化。

java 复制代码
class Solution {
    public int maxSubArray(int[] nums) {
        int ans = Integer.MIN_VALUE; 
        int f = 0;
        for (int x : nums) {
            f = Math.max(f+ x, x) ;
            ans = Math.max(ans, f);
        }
        return ans;
    }
}

这题还可以用前缀和实现,子数组的元素和等于两个前缀和的差,可以一边遍历数组计算前缀和,一边维护前缀和的最小值。由于题目要求子数组不能为空,应当先计算前缀和减去最小前缀和,再更新最小前缀和。

时间复杂度:O(n),空间复杂度:O(1)。

java 复制代码
class Solution {
    public int maxSubArray(int[] nums) {
        int ans = Integer.MIN_VALUE;
        int minPreSum = 0;
        int preSum = 0;
        for (int x : nums) {
            preSum += x; 
            ans = Math.max(ans, preSum - minPreSum); 
            minPreSum = Math.min(minPreSum, preSum); 
        }
        return ans;
    }
}

动态规划要找准状态转移方程及所需更新的状态。

相关推荐
颜酱8 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
架构师沉默12 小时前
别又牛逼了!AI 写 Java 代码真的行吗?
java·后端·架构
zone773913 小时前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
CoovallyAIHub16 小时前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub16 小时前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub16 小时前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉
兆子龙16 小时前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法
后端AI实验室17 小时前
我把一个生产Bug的排查过程,交给AI处理——20分钟后我关掉了它
java·ai
凉年技术19 小时前
Java 实现企业微信扫码登录
java·企业微信
xlp666hub19 小时前
Leetcode第五题:用C++解决盛最多水的容器问题
linux·c++·leetcode