BZOJ 2096: [Poi2010]Pilots( set )
2024-08-26 19:51:41
用个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
5 1 3 5 8 6 6 9 10
Sample Output
4
(有两个子串的长度为4: 5, 8, 6, 6 和8, 6, 6, 9.最长子串的长度就是4)
(有两个子串的长度为4: 5, 8, 6, 6 和8, 6, 6, 9.最长子串的长度就是4)
HINT
Source
最新文章
- header(&#39;Location:&#39;.C(&#39;VIP_HX&#39;).&#39;/CmdId/&#39;.$CmdId.&#39;/user_id/&#39;.$user_id.&#39;/Token/&#39;.$Token);
- 樹的DFS和BFS
- 一段比较有意思的代码——介绍system verilog中的新增幅值语句
- matlab的滤波器仿真——低通滤波器与插值滤波器
- 20145227&;20145201 《信息安全系统设计基础》实验一 开发环境的熟悉
- TI CC2541的引脚中断.
- HDU 4662 MU Puzzle 简单找规律
- iOS UIKit:viewController之动画(5)
- Android登陆界面实现-支持输入框清楚和震动效果功能
- strip 使用命令
- 修改TFS与本地源代码映射路径
- 深入浅出Ajax(四)
- 运维开发工程师 面试题 shell编程
- copy&;deepcopy
- Linux 离线安装Rubygems详解
- Spring系列__01HelloWorld
- JDBC查询MySQL中的表
- net-snmp开发教程
- Python Day 14 迭代器、for循环原理、枚举、生成器
- bind研究(一)转载
热门文章
- Android切换页面效果的实现一:WebView+ViewFlipper
- 达内TTS6.0课件oop_day04
- Building Workspace速度慢的原因
- 红豆带你从零学C#系列之:使用集合组织相关数据
- jQuery中 prop() attr()使用详解
- char *p 和char *p[]
- HDU1159-Common Subsequence
- (4)事件处理——(2)在页面加载的时候执行任务(Performing tasks on page load)
- 获取多个汉字首字母(php)
- python一些模块的exe安装包在windows的64位系统里识别不到已安装Python目录的解决方法