LeetCode hot100-239 滑动窗口最大值

复制代码
class Solution {
public:
    vector<int> maxSlidingWindow(vector<int>& nums, int k) {
        int idx=0;
        int max_num=nums[0];
        vector<int> num;
         for(int i=1;i<k;i++)
        {
          if(nums[i]>=max_num)
         {
            max_num=nums[i];
            idx=i;
         }
        }
        num.emplace_back(max_num);
        for(int i =1;i<=nums.size()-k;i++)
        {
            if(idx>=i)
            {
                if(nums[i+k-1]>=nums[idx])
                {
                    max_num=nums[i+k-1];
                    idx=i+k-1;
                }
                num.emplace_back(max_num);
            }else
            {
                max_num=nums[i];
                idx=i;
                for(int j=i+1;j<i+k;j++)
                {
                    if(nums[j]>=max_num)
                    {
                        max_num=nums[j];
                        idx=j;
                    }
                }
                num.emplace_back(max_num);
            }
        }
        return num;
    }
};
复制代码
   priority_queue<int> maxHeap;//最大堆
复制代码
  priority_queue<int, vector<int>, greater<int>> minHeap;//最小堆
复制代码
priority_queue<pair<int, int>> pq;

// push 需要传入一个已经构造好的 pair 对象
pq.push(pair<int, int>(10, 1));
复制代码
pq.emplace(10, 1);  // 直接传入两个参数,自动构造 pair
复制代码
class Solution {
public:
    vector<int> maxSlidingWindow(vector<int>& nums, int k) {
        int n=nums.size();
        priority_queue<pair<int,int>> q;
        for(int i=0;i<k;i++)
        {
            q.emplace(nums[i],i);
        }
        vector<int> ans={q.top().first};

        for(int i=k;i<n;i++)
        {
            q.emplace(nums[i],i);
            while(q.top().second<=i-k)
            {
                q.pop();
            }
            ans.emplace_back(q.top().first);
        }
        return ans;
    }
};

deque(双端队列)

  • 特点:可以在两端进行插入和删除

queue(队列)

  • 特点:先进先出(FIFO),只能在一端插入,另一端删除

    复制代码
    class Solution {
    public:
        vector<int> maxSlidingWindow(vector<int>& nums, int k) {
          int n=nums.size();
          deque<int> q;
          for(int i=0;i<k;++i)
          {
            while(!q.empty()&&nums[i]>=nums[q.back()])
            {
                q.pop_back();
            }
            q.push_back(i);
          }
          //第一个窗口最大值
          vector<int> ans={nums[q.front()]};
    
          for(int i=k;i<n;i++)//i是滑动窗口的结束位置
          {
            while(!q.empty()&&nums[i]>=nums[q.back()])
            {
               q.pop_back();
            }
            q.push_back(i);
            while(q.front()<=i-k)
            {
                q.pop_front();
            }
    
            ans.emplace_back(nums[q.front()]);
          }
          return ans;
        }
    };
相关推荐
wuweijianlove16 分钟前
算法性能的渐近与非渐近行为对比的技术4
算法
_dindong24 分钟前
cf1091div2 C.Grid Covering(数论)
c++·算法
AI成长日志25 分钟前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
黎阳之光1 小时前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
skywalker_111 小时前
力扣hot100-3(最长连续序列),4(移动零)
数据结构·算法·leetcode
6Hzlia1 小时前
【Hot 100 刷题计划】 LeetCode 17. 电话号码的字母组合 | C++ 回溯算法经典模板
c++·算法·leetcode
wfbcg1 小时前
每日算法练习:LeetCode 209. 长度最小的子数组 ✅
算法·leetcode·职场和发展
_日拱一卒2 小时前
LeetCode:除了自身以外数组的乘积
数据结构·算法·leetcode
计算机安禾2 小时前
【数据结构与算法】第36篇:排序大总结:稳定性、时间复杂度与适用场景
c语言·数据结构·c++·算法·链表·线性回归·visual studio
SatVision炼金士2 小时前
合成孔径雷达干涉测量(InSAR)沉降监测算法体系
算法