首页 > 其他分享 >AcWing 154.滑动窗口

AcWing 154.滑动窗口

时间:2022-10-21 01:35:10浏览次数:59  
标签:输出 窗口 154 int tt hh 滑动 AcWing

AcWing 154.滑动窗口

题目描述

给定一个大小为 n≤10^6的数组。

有一个大小为 k 的滑动窗口,它从数组的最左边移动到最右边。

你只能在窗口中看到 k 个数字。

每次滑动窗口向右移动一个位置。

以下是一个例子:

该数组为 [1 3 -1 -3 5 3 6 7],k
为 3 。

窗口位置 最小值 最大值
[1 3 -1] -3 5 3 6 7 -1 3
1 [3 -1 -3] 5 3 6 7 -3 3
1 3 [-1 -3 5] 3 6 7 -3 5
1 3 -1 [-3 5 3] 6 7 -3 5
1 3 -1 -3 [5 3 6] 7 3 6
1 3 -1 -3 5 [3 6 7] 3 7

你的任务是确定滑动窗口位于每个位置时,窗口中的最大值和最小值。

输入格式

输入包含两行。

第一行包含两个整数 n
和 k ,分别代表数组长度和滑动窗口的长度。

第二行有 n 个整数,代表数组的具体数值。

同行数据之间用空格隔开。

输出格式

输出包含两个。

第一行输出,从左至右,每个位置滑动窗口中的最小值。

第二行输出,从左至右,每个位置滑动窗口中的最大值。

输入样例

8 3
1 3 -1 -3 5 3 6 7

输出样例

-1 -3 -3 -3 3 3
3 3 5 5 6 7

题目思路

用单调队列的思想,如输出最小值时,
入队前将比当前数字大的从队尾出队,输出结果时输出队头,维护一个长度1<=队列长度<=滑动窗口得队列。

#include<cstdio>
#include<iostream>

using namespace std;

const int N = 1e6+10;

int a[N],q[N],hh = 0,tt = -1;

int main()
{
    int n,k;
    cin >> n >> k;
    for(int i=0;i<n;i++)scanf("%d",&a[i]);
    
    for(int i=0;i<n;i++)
    {
        if(hh <= tt && (i - k + 1) > q[hh])hh++;
        while(hh <= tt && a[i] <= a[q[tt]])tt--;
        q[++tt] = i;
        if(i-k+1>=0)
            printf("%d ",a[q[hh]]);
    }
    
    puts("");
    
    hh = 0,tt = -1,q[0] = 0;
    
    for(int i=0;i<n;i++)
    {
        if(hh <= tt && (i - k + 1) > q[hh])hh++;
        while(hh <= tt && a[i] >= a[q[tt]])tt--;
        q[++tt] = i;
        if(i-k+1>=0)
            printf("%d ",a[q[hh]]);
    }
    
    return 0;
}

标签:输出,窗口,154,int,tt,hh,滑动,AcWing
From: https://www.cnblogs.com/fsh001/p/16812145.html

相关文章

  • h5页面在ios上无法滑动与z-index无效的情况
    ps:俩问题产生的原因是引用了scroll.js文件问题一:无法滑动scroll.js文件禁用了滑动事件,在不需要scroll方法的时候,解除禁用即可。/***滑动限制***/stop(){......
  • 2022下半年 Acwing 第二篇:归并模板
    归并其实和快排比较类似,所以模板的记忆也大差不差。不能省懒!voidmerge_sort(intq[],intl,intr){if(l>=r)return;intmid=l+r>>1;merge_s......
  • ACWing 可达性统计
    ACWing可达性统计bitset可以说是一个多位二进制数,每八位占用一个字节,因为支持基本的位运算,所以可用于状态压缩,n位bitset执行一次位运算的时间复杂度可视为n/32.bitset<......
  • acwing 分组背包问题
    题面有N组物品和一个容量是V的背包。每组物品有若干个,同一组内的物品最多只能选一个。每件物品的体积是vij,价值是wij,其中i是组号,j是组内编号。求解将哪些物品......
  • acwing 混合背包问题
    题面有N种物品和一个容量是V的背包。物品一共有三类:第一类物品只能用1次(01背包);第二类物品可以用无限次(完全背包);第三类物品最多只能用si次(多重背包);每种体积是v......
  • acwing 二维费用的背包问题
    题面有N件物品和一个容量是V的背包,背包能承受的最大重量是M。每件物品只能用一次。体积是vi,重量是mi,价值是wi。求解将哪些物品装入背包,可使物品总体积不超过背......
  • 2022下半年 Acwing 第一篇:快排模板
    模板内容:C++voidquick(intq[],intl,intr){if(l>=r)return;intx=q[(l+r+1)>>1],i=l-1,j=r+1;while(i<j){doi++;while(q[i]<x);......
  • jwt 滑动过期方案
    网上大多实现jwt滑动过期的方案要结合Redis,或者返回俩个token,我这里介绍一个稍微简单点的方案,由于 jwt的总的有效时间是expires加上ClockSkew,那么我们就在这个Clo......
  • AcWing1251 打击罪犯--并查集
    #include<bits/stdc++.h>#definepbpush_back#definefifirst#definesesecond#defineall(x)(x).begin(),(x).end()#defineSZ(x)(int)(x).size()usingnam......
  • AcWing 4706 -- 树形DP/DFS
    题目描述4706.最短路程思路dfs代码#include<iostream>#include<cstring>#include<algorithm>#include<vector>usingnamespacestd;constintN=100......