5 条题解

  • 1
    @ 2022-4-8 21:21:03
    #include<iostream>
    #include<cstring>
    #include<algorithm>
    #include<cstdio>
    #include<cstdlib>
    #include<cmath>
    using namespace std;
    int n,m;
    int q1[1000001],q2[1000001];
    int a[1000001];
    int min_deque()
    {
        int h=1,t=0;
        for(int i=1;i<=n;i++)
        {
            while(h<=t&&q1[h]+m<=i) h++;
            while(h<=t&&a[i]<a[q1[t]]) t--;
            q1[++t]=i;
            if(i>=m) printf("%d ",a[q1[h]]);
        }
        cout<<endl;
    }
    int max_deque()
    {
        int h=1,t=0;
        for(int i=1;i<=n;i++)
        {
            while(h<=t&&q2[h]+m<=i) h++;
            while(h<=t&&a[i]>a[q2[t]]) t--;
            q2[++t]=i;
            if(i>=m) printf("%d ",a[q2[h]]);
        }
    }
    int main()
    {
        cin>>n>>m;
        for(int i=1;i<=n;i++) scanf("%d",&a[i]);
        min_deque();
        max_deque();
        return 0;
    }
    

    信息

    ID
    65
    时间
    1000ms
    内存
    128MiB
    难度
    4
    标签
    递交数
    255
    已通过
    121
    上传者