leetcode918.环形子数组的最大和

参考了灵神的题解,然后只要用动态规划求解子数组的最大和和最小和就可以

java 复制代码
class Solution {
    public int maxSubarraySumCircular(int[] nums) {
        int sum = nums[0];
        //变量记录普通子数组的最大和
        int currentMax = nums[0];
        int globalMax = nums[0];
        //变量记录普通子数组的最小和
        int currentMin = nums[0];
        int globalMin = nums[0];

        //动态规划求解普通子数组的最大和和最小和
        for (int i = 1; i < nums.length; i++) {
            sum += nums[i];
            currentMax = Math.max(currentMax + nums[i], nums[i]);
            globalMax = Math.max(globalMax, currentMax);
            currentMin = Math.min(currentMin + nums[i], nums[i]);
            globalMin = Math.min(globalMin, currentMin);
        }
        return sum == globalMin ? globalMax : Math.max(globalMax, sum - globalMin);
    }
}
相关推荐
Wilber的技术分享9 分钟前
【机器学习实战笔记 14】集成学习:XGBoost算法(一) 原理简介与快速应用
人工智能·笔记·算法·随机森林·机器学习·集成学习·xgboost
Tanecious.22 分钟前
LeetCode 876. 链表的中间结点
算法·leetcode·链表
Wo3Shi4七31 分钟前
哈希冲突
数据结构·算法·go
呆呆的小鳄鱼1 小时前
cin,cin.get()等异同点[面试题系列]
java·算法·面试
Touper.1 小时前
JavaSE -- 泛型详细介绍
java·开发语言·算法
sun0077001 小时前
std::forward作用
开发语言·c++·算法
JoernLee1 小时前
机器学习算法:支持向量机SVM
人工智能·算法·机器学习
V我五十买鸡腿1 小时前
顺序栈和链式栈
c语言·数据结构·笔记·算法
我爱一条柴ya2 小时前
【AI大模型】线性回归:经典算法的深度解析与实战指南
人工智能·python·算法·ai·ai编程
七灵微2 小时前
数据结构实验习题
数据结构