首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

URAL1126 Magnetic Storms,deque兑现单调队列

2012-07-31 
URAL1126 Magnetic Storms,deque实现单调队列题目的要求很简单,给出一个数列,给出一个n,问你每n个连续的数

URAL1126 Magnetic Storms,deque实现单调队列

题目的要求很简单,给出一个数列,给出一个n,问你每n个连续的数中最大的是多少。


/******************************************************************************* # Author : Neo Fung # Email : neosfung@gmail.com # Last modified: 2012-07-19 19:35 # Filename: URAL1126 Magnetic Storms.cpp # Description :  ******************************************************************************/#ifdef _MSC_VER//#define DEBUG#define _CRT_SECURE_NO_DEPRECATE#endif#include <fstream>#include <stdio.h>#include <iostream>#include <string.h>#include <string>#include <limits.h>#include <algorithm>#include <math.h>#include <numeric>#include <functional>#include <ctype.h>#include <queue>using namespace std;const int kMAX=10010;struct NODE{int id,val;};int main(void){#ifdef DEBUG    freopen("../stdin.txt","r",stdin);  freopen("../stdout.txt","w",stdout); #endif    int n,ncase=1;NODE node;deque<NODE> q;  while(~scanf("%d",&n) && n)  {q.clear();int cnt=0;while(scanf("%d",&node.val) && node.val>-1){node.id=cnt++;while(!q.empty() && q.front().id < cnt-n)q.pop_front();while(!q.empty() && q.back().val < node.val)q.pop_back();q.push_back(node);if(cnt>=n)printf("%d\n",q.front().val);}  }  return 0;}


热点排行