POJ 3368 Frequent Values

查询某个区间内连续出现次数最多的一个数出现的次数

以前做的时候,没有记录左边连续最多的次数,右边连续最多的次数,而是记录了出现最多的数的值,写的很长,还不知道WA哪了

 

前两天经队友点拨,发现对于这种求最长连续区间的问题,记录左边连续最多的次数(lv),右边连续最多的次数(rv),以及整个区间连续最多次数(val),更新和查询的时候会很方便

 

首先,如果左子区间的lv等于左子区间的长度且可以延伸到右子区间,那么父区间的lv值等于左子区间的lv加上右子区间的lv,否则,父区间的lv值就是左子区间的lv值,对于右子区间,同理

对于父区间的val值,应该是先在左右子区间的val值中取一个较大值,另外,如果左右区间能够延续,则在当前值和左子区间的rv+右子区间的lv之间取较大值

 

还有一个特殊情况就是在查询的时候,如果要分别在左子区间和右子区间查找,结果分别为x,y,如果左右两个区间不能延续,那肯定是在x,y中找一个最大值,如果可以延续的话,设延续部分的最大次数为z,那么,就要在x,y,z中取一个最大值,另外,求z时要比较小心,这个区间的左端点要在向左延伸的最远点和查询区间的左端点中取一个较大值,这个区间的有端点要在向右延伸的最远点和查询区间的有端点间取一个较小值,详情见代码

 

代码:

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值