摘要:
http://poj.org/problem?id=2482A了这题后,我就在想,是不是ACMER都找不到女朋友.....这题看似很新颖,其实就是求线段树区间最值。所谓区间最值,其实就是和RMQ差不多,只不过RMQ是以点为单位,而这个是以区间为单位。怎么扯到区间最值了呢?因为每一颗星星,它都有一个亮度,假设这个星星现在正在最左边,那么它的亮度将会影响到向右W的范围。也就是说[star.x,star.x+W]这个区间都会因为这个亮度的影响而加上这个亮度值,最后求一个[x,x+W]的区间,并且该区间的亮度最大,这就是区间最值!方法和RMQ一样,只是不是更新到节点,而是更新到相应线段即可!这里还要注 阅读全文
摘要:
http://poj.org/problem?id=3225这题很有意思,对于[0,65535]这么一个区间,初始值为0,问最后为连续1的子区间有哪些。很有趣的是,这题涉及到了开区间和闭区间,即() 和 [] 。确是比较棘手!解决的办法是将所给的数据范围乘以2,然后根据给的是开区间或则是闭区间修改数据,例如:给你(2,3]这样的数据,如何处理呢?我们将范围乘以2,得到(4,6],然后,如果左边是开区间,则将4加1,得到5,同理,如果右边是开区间,则将6减去一个1。为什么这样做呢? 看看,因为数据乘以2后,得到的结果一定是偶数,而偶数加一减一后,肯定得到奇数。也就是说,如果最后得到的数据是偶数, 阅读全文