码迷,mamicode.com
首页 > 其他好文 > 详细

给出一个长度为n的数列,请对于每一个数,输出他右边第一个比他大的数。n<=100000.

时间:2014-08-05 00:15:58      阅读:302      评论:0      收藏:0      [点我收藏+]

标签:strong   时间   log   第一个   on   百度   方法   情况   

RT,一个ppt里看到的题,不过没讲做法。百度上基本搜不到。自己想了个做法,理论上可行,复杂度也是O(nlogn)。

首先,做一次RMQ,求区间最大值。

对于任意一个数s[i],可以用logn的时间求出他右边第一个比他大的数:

RMQ[i][j] 表示从s[i]开始的2^j个数中的最大值。对于确定的i,RMQ[i][j]随着j的增大肯定是非降的

先判断无解的情况,只要看max(RMQ[i][j],RMQ[n-2^j+1][j]) ,也就是区间[i,n]的最大值是否比s[i]大即可(下面求区间最大值也用该方法,就不写明了),如果是,可能有解,反之无解。

如果有解,也就是在区间[i+1,n]里找到第一个大于s[i]的数;

 

把区间二分,如果左边一半的最大值大于S[i],那么就到左边一半寻找答案,如果左边一半的最大值小于S[i],就到右边一半找,每次查找的范围都缩小了一半。

n个数,每次logn,总的时间复杂度是nlogn。

给出一个长度为n的数列,请对于每一个数,输出他右边第一个比他大的数。n<=100000.,布布扣,bubuko.com

给出一个长度为n的数列,请对于每一个数,输出他右边第一个比他大的数。n<=100000.

标签:strong   时间   log   第一个   on   百度   方法   情况   

原文地址:http://www.cnblogs.com/vb4896/p/3891101.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!