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;
        }
    };
相关推荐
m0_743297422 小时前
嵌入式LinuxC++开发
开发语言·c++·算法
2301_800895102 小时前
求最小生成树kruskal还是prim--备战蓝桥杯版h
算法
小小怪7502 小时前
高性能密码学库
开发语言·c++·算法
Book思议-2 小时前
【数据结构实战】 C 语言单链表通关:初始化 / 头插 / 尾插 / 增删改查全实现(附图解、可运行完整代码)
c语言·数据结构·算法
2301_821700532 小时前
模板代码生成工具
开发语言·c++·算法
wuhen_n2 小时前
回溯算法入门 - LeetCode经典回溯算法题
前端·javascript·算法
宵时待雨2 小时前
C++笔记归纳12:二叉搜索树
开发语言·数据结构·c++·笔记·算法
炎爆的土豆翔2 小时前
SIMD常见操作,结合样例一文理解
开发语言·c++·算法
仰泳的熊猫2 小时前
题目2305:蓝桥杯2019年第十届省赛真题-等差数列
数据结构·c++·算法·蓝桥杯