用个set维护就可以水过去...O(NlogN)

应该可以用单调队列O(N)....

----------------------------------------------------------------------

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<set>
 
using namespace std;
 
const int maxn = 3000009;
 
int lim, N, seq[maxn];
multiset<int> S;
multiset<int> :: iterator It[maxn];
 
int main() {
scanf("%d%d", &lim, &N);
for(int i = 0; i < N; i++) 
scanf("%d", seq + i);
S.clear();
It[0] = S.insert(seq[0]);
int ans = 0, p = 0;
for(int i = 1; i < N; i++) {
for(; ;) {
set<int> :: iterator Min = S.begin(), Max = S.end();
if(Min == Max) break;
if(abs(seq[i] - *Min) <= lim && abs(seq[i] - *--Max) <= lim) break;
S.erase(It[p++]);
}
It[i] = S.insert(seq[i]);
ans = max(ans, i - p + 1);
}
if(N == 1)
puts("1");
else
printf("%d\n", ans);
return 0;
}

----------------------------------------------------------------------

2096: [Poi2010]Pilots

Time Limit: 30 Sec  Memory Limit: 162 MB
Submit: 492  Solved: 255
[Submit][Status][Discuss]

Description

Tz又耍畸形了!!他要当飞行员,他拿到了一个飞行员测试难度序列,他设定了一个难度差的最大值,在序列中他想找到一个最长的子串,任意两个难度差不会超过他设定的最大值。耍畸形一个人是不行的,于是他找到了你。

Input

输入:第一行两个有空格隔开的整数k(0<=k<=2000,000,000),n(1<=n<=3000,000),k代表Tz设定的最大值,n代表难度序列的长度。第二行为n个由空格隔开的整数ai(1<=ai<=2000,000,000),表示难度序列。

Output

输出:最大的字串长度。

Sample Input

3 9
5 1 3 5 8 6 6 9 10

Sample Output

4
(有两个子串的长度为4: 5, 8, 6, 6 和8, 6, 6, 9.最长子串的长度就是4)

HINT

Source

最新文章

  1. header(&#39;Location:&#39;.C(&#39;VIP_HX&#39;).&#39;/CmdId/&#39;.$CmdId.&#39;/user_id/&#39;.$user_id.&#39;/Token/&#39;.$Token);
  2. 樹的DFS和BFS
  3. 一段比较有意思的代码——介绍system verilog中的新增幅值语句
  4. matlab的滤波器仿真——低通滤波器与插值滤波器
  5. 20145227&amp;20145201 《信息安全系统设计基础》实验一 开发环境的熟悉
  6. TI CC2541的引脚中断.
  7. HDU 4662 MU Puzzle 简单找规律
  8. iOS UIKit:viewController之动画(5)
  9. Android登陆界面实现-支持输入框清楚和震动效果功能
  10. strip 使用命令
  11. 修改TFS与本地源代码映射路径
  12. 深入浅出Ajax(四)
  13. 运维开发工程师 面试题 shell编程
  14. copy&amp;deepcopy
  15. Linux 离线安装Rubygems详解
  16. Spring系列__01HelloWorld
  17. JDBC查询MySQL中的表
  18. net-snmp开发教程
  19. Python Day 14 迭代器、for循环原理、枚举、生成器
  20. bind研究(一)转载

热门文章

  1. Android切换页面效果的实现一:WebView+ViewFlipper
  2. 达内TTS6.0课件oop_day04
  3. Building Workspace速度慢的原因
  4. 红豆带你从零学C#系列之:使用集合组织相关数据
  5. jQuery中 prop() attr()使用详解
  6. char *p 和char *p[]
  7. HDU1159-Common Subsequence
  8. (4)事件处理——(2)在页面加载的时候执行任务(Performing tasks on page load)
  9. 获取多个汉字首字母(php)
  10. python一些模块的exe安装包在windows的64位系统里识别不到已安装Python目录的解决方法