zoukankan      html  css  js  c++  java
  • 【洛谷P1886】滑动窗口【单调队列】

    题目大意:

    题目链接:https://www.luogu.org/problemnew/show/P1886
    给出n,m和一个含有n个元素的数列,求每个连续的长度为m的子串的最小值和最大值。


    思路:

    暴力O(N2),可以用单调队列优化。
    每次维护两个单调队列,保证答案就是maxn.front()minn.front(),并及时将早来的踢掉,后来的入队。时间复杂度O(n)


    代码:

    #include <cstdio>
    #include <algorithm>
    #include <queue>
    using namespace std;
    
    deque<int> minn;
    deque<int> maxn;
    int n,m,a[1000001],ans_min[1000001],ans_max[1000001];
    
    int main()
    {
        scanf("%d%d",&n,&m);
        for (int i=1;i<=n;i++)
        {
            scanf("%d",&a[i]);
            while (minn.size()&&a[minn.back()]>a[i]) minn.pop_back();
            while (maxn.size()&&a[maxn.back()]<a[i]) maxn.pop_back();  //维护,保持单调
            minn.push_back(i);
            maxn.push_back(i);  //入队
            if (i>=m)
            {
                while (i-m>=minn.front()) minn.pop_front();
                while (i-m>=maxn.front()) maxn.pop_front();  //踢掉早来的(窗口右移)
                ans_min[i-m+1]=a[minn.front()];
                ans_max[i-m+1]=a[maxn.front()];  //记录答案
            }
        }
        for (int i=1;i<=n-m+1;i++)
         printf("%d ",ans_min[i]);
        printf("\n");
        for (int i=1;i<=n-m+1;i++)
         printf("%d ",ans_max[i]);
        return 0;
    }
  • 相关阅读:
    C#结构
    R语言快速入门
    C#_枚举类型
    C#_数组
    C#传递参数
    C#_字符串的操作
    python-函数之命名空间作用域
    python-迭代器和生成器
    python-文件操作
    python
  • 原文地址:https://www.cnblogs.com/hello-tomorrow/p/11998722.html
Copyright © 2011-2022 走看看