• 【打卡】牛客网:BM45 滑动窗口的最大值


    模板的:

    • dq存储索引(因为要判断该阶段的最大值,在窗口移动后是否还在),res存储最终的值。
    • res每次取dq的第一个。dq的第一个永远最优。因为窗口移动后,会删除dq中【旧的】、【比新进入的值小的】(题目求最大值)值的索引。(注:删除时从后面开始删除,可以删光,这时说明新进入的值是最大的)
    • 之所以要把新进入的值无论如何都要放进来,是要作为备选,防止dq的第一个值被窗口移走。(注:放进来时从后面开始放)
    1. class Solution {
    2. public:
    3. /**
    4. * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
    5. *
    6. *
    7. * @param num int整型vector
    8. * @param size int整型
    9. * @return int整型vector
    10. */
    11. vector<int> maxInWindows(vector<int>& num, int size) {
    12. // write code here
    13. vector<int> res;
    14. if(size <= num.size() && size != 0){
    15. deque<int> dq;
    16. for(int i = 0; i < size; i++){
    17. while(!dq.empty() && num[dq.back()] < num[i])
    18. dq.pop_back();
    19. dq.push_back(i);
    20. }
    21. for(int i = size; i < num.size(); i++){
    22. res.push_back(num[dq.front()]);
    23. // 粗心,双向队列没有dq.top(),栈有
    24. // 粗心,不是res.push_back(dq.front());
    25. if(dq.front() < i - size + 1)
    26. //模板里面用了while,但是窗口划动的步长是1,所以不影响
    27. dq.pop_front();
    28. while(!dq.empty() && num[dq.back()] < num[i])
    29. dq.pop_back();
    30. dq.push_back(i);
    31. }
    32. res.push_back(num[dq.front()]); //粗心,比较难想到
    33. }
    34. return res;
    35. }
    36. };

  • 相关阅读:
    关于网络协议的若干问题(一)
    使用 Juju/MAAS 部署 OpenStack
    Keepalived 高可用详解
    python常用标准库(时间模块time和datetime)
    docker容器常用命令
    MFC Windows 程序设计[329]之多彩下拉组合编辑框实例(附源码)
    Java实现CAS的原理
    计算机网络中拥塞控制的门限值怎么设置
    Linux系统---nginx(4)负载均衡
    .NET周刊【6月第1期 2024-06-02】
  • 原文地址:https://blog.csdn.net/weixin_47173826/article/details/134355042