莫队

极好的blog
https://www.cnblogs.com/WAMonster/p/10118934.html

概要

概述一下,就是区间上的双指针+分块+排序优化的优美暴力
一般情况下块长取n
复杂度O(nn)

块长选取

我们令数列长度为n,询问m个,块长s,左端点位于第i块的询问数量为qi
那么最劣时间复杂度应是

i=1nsqis+n=ms+nns

由基本不等式可得
smin=nm

此时算法效率最高
对于一般或者回滚莫队,还是常用 n为块长
带修的莫队一般取n23为块长

扩展顺序

莫队的双指针扩展顺序(下面是一种正确的且好记的写法)

                while(l>q[i].l) add(--l);
		while(r<q[i].r) add(++r);
		while(l<q[i].l) del(l++);
		while(r>q[i].r) del(r--);
posted @   Diamondan  阅读(11)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 【杂谈】分布式事务——高大上的无用知识?
点击右上角即可分享
微信分享提示