day96(2.25)——leetcode面试经典150

53. 最大子数组和

53. 最大子数组和

题目:

题解:

java 复制代码
class Solution {
    public int maxSubArray(int[] nums) {
        //当前选自己 or 接着加,全局取最大
        //贪心+一维动态规划
        //当前最优解,全局最优解
        int currentRes = nums[0];
        int maxRes = nums[0];
        for(int i=1;i<nums.length;i++) {
            currentRes = Math.max(currentRes+nums[i], nums[i]);
            maxRes = Math.max(currentRes, maxRes);
        }
        return maxRes;
    }
}

918. 环形子数组的最大和

918. 环形子数组的最大和

题目:

题解:

java 复制代码
class Solution {
    public int maxSubarraySumCircular(int[] nums) {
        int minCurRes = nums[0], maxCurRes = nums[0];
        int minRes = nums[0], maxRes = nums[0];
        int total = nums[0];
        for(int i=1;i<nums.length;i++) {
            minCurRes = Math.min(minCurRes+nums[i], nums[i]);
            minRes = Math.min(minRes, minCurRes);
            
            maxCurRes = Math.max(maxCurRes+nums[i], nums[i]);
            maxRes = Math.max(maxRes, maxCurRes);
            
            total+=nums[i];
        }

        //说明全是负数
        if(maxRes < 0) {
            return maxRes;
        }

        return Math.max(maxRes, total-minRes);
    }
}
相关推荐
小欣加油29 分钟前
leetcode56 合并区间
c++·算法·leetcode·职场和发展
lqqjuly38 分钟前
前沿算法深度解析(二)
人工智能·算法·机器学习
不懂数据的小白1 小时前
面试题一:【二】异动分析(诊断)
面试
Aphasia3112 小时前
https连接传输流程
前端·面试
徐小夕2 小时前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
akunkuntaimei2 小时前
2026年高考数学各省真题及答案(完整版)
算法·高考
kyriewen2 小时前
CSS Container Queries:彻底告别 @media 写到手软,附 5 个真实布局案例
前端·css·面试
Hello:CodeWorld3 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi84 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
mONESY5 小时前
JavaScript 栈、队列、数组与链表核心知识点总结
javascript·面试