leetcode 239 单调队列 需要一些记忆

滑动窗口最大值,刚看到,一种朴素的思想扑面而来,就是优先队列+map,是可以解决这个问题的,就是空间复杂度稍高,并且不优雅,并且 O(NlogN)

一种更为优雅的做法是单调队列,这个就稍微比较考验技巧了,如果是第一次听说,最好还是全文背诵。。。

这里,存下标的原因是,由于我们可能会把队里的元素删光,所以不知道最前面的是不是该被删的老的,还是新放的,放下标的处理会更为简单,代码如下:

cpp 复制代码
typedef vector<int> V;

class Solution {
public:
    vector<int> maxSlidingWindow(vector<int>& nums, int k) {
        deque<int> q;
        V ans;

        int n = nums.size();
        
        for(int i=0;i<n;i++)
        {
            int num = nums[i];
            while(q.size() > 0 && nums[q.back()] <= num)q.pop_back();

            while(q.size() > 0 && q.front() <= i-k)q.pop_front();

            q.push_back(i);

            if(i>=k-1)
            ans.push_back(nums[q.front()]);
        }

        return ans;
    }
};
相关推荐
Matrix_1115 分钟前
手机里的计算摄影:广角形变校正算法
人工智能·算法·智能手机·计算摄影
WBluuue20 分钟前
数据结构与算法:有序表(二):跳表
数据结构·c++·算法·skiplist
IT龟苓膏38 分钟前
并发深度解析】硬核手撕 ForkJoinPool + WorkStealing + CompletableFuture 底层源码与大厂面试演练
面试·职场和发展
x138702859572 小时前
c语言中srtlen(指针使用计算字符长度)、传值和传址调用
c语言·开发语言·算法·visual studio
海兰2 小时前
【实用程序】电商销售分析仪表盘 — 从零搭建一个AI参与的全栈数据洞察系统
人工智能·学习·算法
zwenqiyu2 小时前
P5283 [十二省联考 2019] 异或粽子题解
c++·学习·算法
wayz112 小时前
Momentum:TSI(真实强度指数)技术指标详解
算法·金融·数据分析·量化交易·特征工程
万事大吉CC3 小时前
Python 笔试输入模板总结
python·算法
lihao lihao3 小时前
Linux信号
开发语言·c++·算法
大白话_NOI3 小时前
【洛谷 P2249】查找(深基 13. 例 1)+ 详细分析
c++·算法