BZOJ 1307: 玩具 单调队列(滑动难想)

1307: 玩具
Time Limit: 10 Sec  Memory Limit: 162 MB
Submit: 554  Solved: 281
[Submit][Status][Discuss]
Description
小球球是个可爱的孩子,他喜欢玩具,另外小球球有个大大的柜子,里面放满了玩具,由于柜子太高了,每天小球球都会让妈妈从柜子上拿一些玩具放在地板上让小球球玩。 这天,小球球把所有的N辆玩具摆成一排放在地上,对于每辆玩具i,小球球都会给它涂上一个正整数value[i],以表示小球球对该玩具的喜爱程度,value[i]越小则表示他越喜爱。当然对于两辆不同的玩具u,v(u<>v),亦有可能value[i]=value[j],也就是说小球球对u,v两车的喜爱程度是一样的。 小球球很贪玩,他希望能从中间某个位置,连续的取出k辆玩具,使得这k辆车里喜爱程度最大的一辆车的喜爱程度正好等于k,且这k辆车中没有两辆车的喜爱程度是相同的。小球球希望知道k的最大值为多少。
Input
第一行一个整数N,表示小球球拥有的玩具数量。 接下来N行,每行一个整数,表示value[i]。
Output
一个整数k,即答案。
Sample Input
6
2
4
1
3
2
1

Sample Output
4

HINT
1<=Value[i]<=10^6
10%的测试数据 N<=10^5。
100%的测试数据 N<=10^6

Source

[Submit][Status][Discuss]

 

分析:

本题两个问题需要解决,且是动态的,所以考虑用单调队列,单调队列维护一个递减的序列就可以快速查询最大值的问题,什么时候需要滑窗(更新区间长度)呢,就是要等到有一个相同的数x进来的时候,借助一个桶排思想记录出现的值,并且更新掉小于上一次x出现的所有位置,具体实现细节看代码,不难理解。

定义区间最大值:单调队列

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值