918. 环形子数组的最大和

这道题我们用双端队列解决。首先将数组扩展为两倍,用i%n即可成立,然后使用前缀和去求解最大的字串和。

prei是固定的所以每次找到最小的prej即可,再将每次最大的值放到res中即可。并且要维护这个队列使其递增,这样每次取头部元素即可,因为长度不超过n,所以i-j小于n的就出队,并且前缀和大于当前前缀和的从尾部出队,这要可以保证递增性,也能保证不丢失可能存在的解。

cpp 复制代码
class Solution {
public:
    int maxSubarraySumCircular(vector<int>& nums) {
        int n=nums.size();
        int pre=nums[0],res=nums[0];
        deque<pair<int,int>> q;
        q.push_back({0,pre});
        for(int i=1;i<2*n;i++){
            while(!q.empty()&&q.front().first<i-n){
                q.pop_front();
            }
            pre+=nums[i%n];
            res=max(res,pre-q.front().second);
            while(!q.empty()&&q.back().second>=pre){
                q.pop_back();
            }
            q.push_back({i,pre});
        }
        return res;
    }
};
相关推荐
阿阿阿阿里郎1 小时前
ROS2快速入门--C++基础
开发语言·c++·算法
free-elcmacom1 小时前
C++<x>new和delete
开发语言·c++·算法
lxh01131 小时前
计算右侧小于当前元素的个数 题解
javascript·数据结构·算法
滴滴答滴答答1 小时前
机考刷题之 12 LeetCode 684 冗余的边
算法·leetcode·职场和发展
美式请加冰2 小时前
前缀数组的介绍和使用
数据结构·c++·算法
IronMurphy2 小时前
【算法十九】33. 搜索旋转排序数组 74. 搜索二维矩阵
线性代数·算法·矩阵
Srend6662 小时前
【图论】最短路问题
算法·图论
云泽8082 小时前
蓝桥杯算法精讲:二分算法之二分查找深度剖析
算法·职场和发展·蓝桥杯
电报号dapp1192 小时前
公链浏览器:区块链世界的“数据透视镜”与哈希查询的艺术
算法·区块链·智能合约·哈希算法