P1440 求m区间内的最小值(单调队列)

简介: 算法

题意:

10.png

思路:用单调队列去不断进行筛数操作,O(n)扫一遍,两个while第一个while是使队列是单调的,如果不符合就弹数,第二个while是使队列里的元素要满足前m个。

#include<bits/stdc++.h>
using namespace std;
const int maxn=2e6+100;
int a[maxn];
deque<int >m1;
int main()
{
    int n,m;
    scanf("%d%d",&n,&m);
    printf("%d\n",0);
    for(int i=1;i<n;i++){
        scanf("%d",&a[i]);
        while(m1.size()&&a[m1.back()]>a[i]){
            m1.pop_back();
        }
        m1.push_back(i);
        while(i-m>=m1.front()){
            m1.pop_front();
        }
        printf("%d\n",a[m1.front()]);
    }
    return 0;
}
相关文章
|
前端开发 JavaScript
使用 JavaScript 实现图片预览功能
使用 JavaScript 实现图片预览功能
384 0
|
人工智能 算法 BI
【洛谷 P1803】凌乱的yyy _ 线段覆盖 题解(贪心算法+结构体排序)
**线段覆盖问题**: YYY 想在 NOIP 前参加最多比赛。给定 $n$ 场比赛的开始和结束时间,每场比赛必须连续且不能冲突。输入包含每场比赛的时间段,输出最多可参加的比赛数。$20\%$ 数据 $n\leq10$,$50\%$ 数据 $n\leq10^3$,$100\%$ 数据 $n\leq10^6$。解决方案:按结束时间排序比赛,若当前比赛开始时间晚于上一个结束时间,则计数加一。样例输入:3 场比赛,输出:2。AC C++ 代码实现了此算法。
128 0
|
C++
【PTA】​ L1-080 乘法口诀数列​(C++)
【PTA】​ L1-080 乘法口诀数列​(C++)
184 0
【PTA】​ L1-080 乘法口诀数列​(C++)
经典递归问题:汉诺塔【超详解】
经典递归问题:汉诺塔【超详解】
2108 0
|
算法 Java
算法-称硬币(枚举-java)
算法-称硬币(枚举-java)
|
4天前
|
云安全 人工智能 安全
AI被攻击怎么办?
阿里云提供 AI 全栈安全能力,其中对网络攻击的主动识别、智能阻断与快速响应构成其核心防线,依托原生安全防护为客户筑牢免疫屏障。
|
14天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~