leetcode239 滑动窗口最大值

一、问题描述

二、解题思路

利用滑动窗口+哈希map来解决这个问题,map来记录窗口中元素出现的次数,map的键是窗口中的数,值为该数字在窗口中出现的次数。由于map的底层实现是红黑树,所以hash.rbegin()->first就是当前窗口中最大的数,将其加入ret向量即可。

三、代码实现

cpp 复制代码
class Solution {
public:
    vector<int> maxSlidingWindow(vector<int>& nums, int k) {
        //滑动窗口+哈希表<数组元素(int),出现的次数(int)>
        //特殊情况
        vector<int> ret;
        int n=nums.size();
        if(n<k) return ret;
        
        //正常情况
        map<int,int> hash;
        //窗口扩张
        int left=0,right=-1;
        for(int i=0;i!=k;i++)  hash[nums[++right]]++;
        int add=hash.rbegin()->first;
        ret.push_back(add);

        //窗口后移
        for(int i=k;i!=nums.size();i++){
            //添加最右侧的元素
            hash[nums[++right]]++;
            //剔除最左侧的元素
            hash[nums[left]]--;
            if(hash[nums[left]]==0) hash.erase(nums[left]);
            left++;
            //加入ret
            add=hash.rbegin()->first;
            ret.push_back(add);
        }
        return ret;
    }
};
相关推荐
To_OC11 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户9385156350716 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC17 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥17 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者19 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者19 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月1 天前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星1 天前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星1 天前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试