【算法】用存入下标的方法来巧解单调队列

 前言:

本系列是看的B站董晓老师所讲的知识点做的笔记

董晓算法的个人空间-董晓算法个人主页-哔哩哔哩视频 (bilibili.com)

C单调队列

P1886 滑动窗口 /【模板】单调队列 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

k为窗口的大小

维护最小值就是维护窗口内的升序子序列

维护最大值就是维护窗口内的降序子序列

思想:

q[]数组中存放的是元素的下标,队尾出队(判断大小)进队(存入下标),对头出队(判断距离)

 // 维护窗口最小值
  int h=1, t=0;                       //头尾指针初值
  for(int i=1; i<=n; i++){
    while(h<=t && a[q[t]]>=a[i]) t--; //队尾出队(队列不空且新元素更优)
    q[++t]=i;                         //队尾入队(存储下标 方便判断队头出队)
    if(q[h]<i-k+1) h++;               //队头出队(队头元素滑出窗口)
    if(i>=k) printf("%d ", a[q[h]]);  //输出最值
  }

相关推荐

  1. 算法存入下标方法单调队列

    2024-05-09 08:12:02       39 阅读
  2. 队列——数组表示

    2024-05-09 08:12:02       33 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-09 08:12:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-09 08:12:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-05-09 08:12:02       87 阅读
  4. Python语言-面向对象

    2024-05-09 08:12:02       96 阅读

热门阅读

  1. 【linux】隐藏文件,vim 或 gedit 打开隐藏文件

    2024-05-09 08:12:02       30 阅读
  2. 探索九型人格测试API接口:神奇之处暗藏何处?

    2024-05-09 08:12:02       27 阅读
  3. Amazon IoT 服务的组件

    2024-05-09 08:12:02       34 阅读
  4. docker安装部署FastGPT

    2024-05-09 08:12:02       29 阅读
  5. selenium 同样的class如何选择第二个

    2024-05-09 08:12:02       33 阅读
  6. C#语言进阶(四) 枚举器和迭代器

    2024-05-09 08:12:02       35 阅读
  7. Spring Boot配置类实例讲解

    2024-05-09 08:12:02       34 阅读