博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ_2823 Sliding Window(单调队列)
阅读量:6226 次
发布时间:2019-06-21

本文共 1103 字,大约阅读时间需要 3 分钟。

  很裸的单调队列问题,不过O(n)的算法写出来5188+ms,超5s了。。。谁能告诉我500+ms的神级代码是什么。。.T_T

My Code:

 

#include 
#include
#include
using namespace std; const int N = 1000005; struct node {
int i; int num; }q[N]; int ans[N]; int b[N]; int main() {
//freopen("data.in", "r", stdin); int n, k, i, f, r; while(~scanf("%d%d", &n, &k)) {
getchar(); for(i = 0; i < n; i++) scanf("%d", &b[i]); for(f = r = i = 0; i < n; i++) {
if(f < r && q[f].i <= i - k) f++; while(f < r && q[r-1].num >= b[i]) r--; q[r].i = i; q[r].num = b[i]; r++; ans[i] = q[f].num; } for(i = k-1; i < n; i++) {
printf("%d", ans[i]); if(i != n-1) putchar(''); else putchar('\n'); } for(f = r = i = 0; i < n; i++) {
if(f < r && q[f].i <= i - k) f++; while(f < r && q[r-1].num <= b[i]) r--; q[r].i = i; q[r].num = b[i]; r++; ans[i] = q[f].num; } for(i = k-1; i < n; i++) {
printf("%d", ans[i]); if(i != n-1) putchar(''); else putchar('\n'); } } return 0; }

转载地址:http://nznna.baihongyu.com/

你可能感兴趣的文章
JavaScript 数据类型
查看>>
量子通信和大数据最有市场突破前景
查看>>
对‘初学者应该选择哪种编程语言’的回答——计算机达人成长之路(38)
查看>>
如何申请开通微信多客服功能
查看>>
Sr_C++_Engineer_(LBS_Engine@Global Map Dept.)
查看>>
非监督学习算法:异常检测
查看>>
jquery的checkbox,radio,select等方法总结
查看>>
Linux coredump
查看>>
Ubuntu 10.04安装水晶(Mercury)无线网卡驱动
查看>>
Myeclipes快捷键
查看>>
ToRPC:一个双向RPC的Python实现
查看>>
我的友情链接
查看>>
nginx在reload时候报错invalid PID number
查看>>
神经网络和深度学习-第二周神经网络基础-第二节:Logistic回归
查看>>
Myeclipse代码提示及如何设置自动提示
查看>>
c/c++中保留两位有效数字
查看>>
ElasticSearch 2 (32) - 信息聚合系列之范围限定
查看>>
VS2010远程调试C#程序
查看>>
[MicroPython]TurniBit开发板DIY自动窗帘模拟系统
查看>>
由String类的Split方法所遇到的两个问题
查看>>