栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

poj 2823 Sliding Window

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

poj 2823 Sliding Window

#include <cstdio>#include <queue>using namespace std;int a[1000010];deque<int> q1,q2;int main(){    int n,k;    scanf("%d%d",&n,&k);    for (int i = 0;i < n; ++ i)        scanf("%d",&a[i]);    for (int i = 0;i < k ; ++ i)    {        if (q1.empty()) q1.push_back(i);        else        { while (!q1.empty() && a[q1.back()] > a[i])     q1.pop_back(); q1.push_back(i);        }        if (q2.empty()) q2.push_back(i);        else        { while (!q2.empty() && a[q2.back()] < a[i])     q2.pop_back(); q2.push_back(i);        }    }    printf("%d",a[q1.front()]);    for (int i = k;i < n; ++ i)    {        if (q1.front() < i - k + 1) q1.pop_front();        while (!q1.empty() && a[q1.back()] > a[i]) q1.pop_back();        q1.push_back(i);        printf(" %d",a[q1.front()]);    }    printf("n");    printf("%d",a[q2.front()]);    for (int i = k;i < n; ++ i)    {        if (q2.front() < i - k + 1) q2.pop_front();        while (!q2.empty() && a[q2.back()] < a[i]) q2.pop_back();        q2.push_back(i);        printf(" %d",a[q2.front()]);    }    printf("n");    return 0;}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/380121.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号