码农知识堂 - 1000bd
Python
PHP
JS/TS
JAVA
C/C++
C#
GO
Kotlin
Swift
普通莫队小结
无修改普通莫队大致的步骤如下:
1.读入所有询问,离线解决
2.按照左端点将询问分块
3.以分块为第一关键字,右端点为第二关键字排序
4.按照排序的顺序依次解决所有的询问
可以使用奇偶性优化加快排序
首先通过一个问题来引入
问题:给你一个长度为n的数组,有m次查询,每次查询询问一个区间[L, R]内有多少个不同的数
首先想想暴力怎么做
开一个数组用来记数,然后扫一遍[L,R],如果这个数是第一次出现,那么对答案贡献+1
暴力出来的时间复杂度是O(n*m),如果n、m较大,那暴力肯定是不行的。
再想想进一步优化
开两个指针 l 和 r,将之前的每次扫区间[L,R]改成移动指针l、r,使得指针与区间边界对齐
在移动指针的时候,对应地去删除或添加对答案的贡献即可
但问题来了,如果每次询问的区间[L,R]都需要移动很长的距离,就比如第一次询问[1,2],第二次询问[n-1,n],出现了一个指针反复横跳的情况
这么一来时间复杂度依旧是O(n*m)
优化了个寂寞
这就需要我们给这些询问一个顺序,使得移动次数最小
,这样我们可以利用上一次询问得到的信息来处理当前询问,大大加快速度
回到刚才的第二种思路,我们可不可以在原来的基础上,对左区间进行排序以保证指针l不会移动到曾经被左指针扫过的地方,思想是好的,但是不能确保指针r的移动不重复,所以还是不行
这个时候就需要进行分块
核心是分块和排序:将长度为n的数组分为若干个块,每个块内有sqrt(n)个元素,再将每个块按顺序编号,然后排序(对于区间左端点来说,如果在同一个块内,就按右端点排序,否则按左端点排序)
如果足够细心应该会注意到,对要询问的区间进行排序,那将会打乱原有的询问顺序
换而言之,必须要先输入所有询问,再一次性输出所有对应的答案,也就是我们通常所说的离线操作
相关阅读:
java毕业设计—— 基于java+javaEE+jsp的项目管理系统设计与实现(毕业论文+程序源码)——项目管理系统
今年最后一次PMP考试!想升职加薪抓紧!
基于RASC的keil电子时钟制作(瑞萨RA)(7)----配置RTC时钟及显示时间
【总结】坐标变换和过渡矩阵(易忘记)
Spring Boot集成protobuf快速入门Demo
十五、项目构建与部署
七、【Vue-Router】router-link标签的replace属性
Mysql存储-EAV模式
MySQL数据库基础操作
Java筑基32-IO流02-节点流&处理流
原文地址:https://blog.csdn.net/weixin_59624686/article/details/126200900
最新文章
攻防演习之三天拿下官网站群
数据安全治理学习——前期安全规划和安全管理体系建设
企业安全 | 企业内一次钓鱼演练准备过程
内网渗透测试 | Kerberos协议及其部分攻击手法
0day的产生 | 不懂代码的"代码审计"
安装scrcpy-client模块av模块异常,环境问题解决方案
leetcode hot100【LeetCode 279. 完全平方数】java实现
OpenWrt下安装Mosquitto
AnatoMask论文汇总
【AI日记】24.11.01 LangChain、openai api和github copilot
热门文章
十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
奉劝各位学弟学妹们,该打造你的技术影响力了!
五年了,我在 CSDN 的两个一百万。
Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
面试官都震惊,你这网络基础可以啊!
你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
心情不好的时候,用 Python 画棵樱花树送给自己吧
通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
13 万字 C 语言从入门到精通保姆级教程2021 年版
10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系
2656653265@qq.com
京ICP备2022015340号-1
正则表达式工具
cron表达式工具
密码生成工具
京公网安备 11010502049817号