严格的摸鱼查询题解

考虑暴力覆盖,复杂度可能会到O(n^2)级别。
实际上,暴力覆盖最多覆盖O(n)级别的位置,很多位置被重复覆盖了。
可以采用线段树来记录一个区间是否被全部覆盖过,但是这样做并不是很简单,我们可以采用其他的方法。
在记录覆盖的时候,覆盖过的位置记录为从此位置开始,最右端被覆盖过的位置是哪里。
这样暴力的时候就可以直接跳。
复杂度变成了总的O(n)级别,因为每个位置最多被覆盖1次,总的复杂度也就是O(n)级别了。

全部评论

相关推荐

头像
10-09 19:35
门头沟学院 Java
洛必不可达:java的竞争激烈程度是其他任何岗位的10到20倍
点赞 评论 收藏
分享
10-18 13:01
已编辑
西安理工大学 C++
小米内推大使:建议技能还是放上面吧,hr和技术面试官第一眼想看的应该是技能点和他们岗位是否匹配
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务