数列分块入门

文章目录

    • 数列分块入门1
    • 数列分块入门2
    • 数列分块入门3
    • 数列分块入门4
    • 数列分块入门5
    • 数列分块入门6
    • 数列分块入门7
    • 数列分块入门8
    • 数列分块入门9

数列分块入门1

区间加,单点查询
分块后,维护标记,零散块暴力加,查询时输出值加标记

数列分块入门2

区间加,询问区间小于等于k的元素个数
每个区间维护排序数组,这样复杂度是根号带一个log,然后每次修改对于整块打标记,对于零散块直接暴力重构,注意暴力重构的时候不用管标记,因为标记相当于整体平移,和顺序无关。

数列分块入门3

区间加,询问区间k的前驱
和2类似,我们还是维护排序数组,然后对于修改,零散块重构,整块打标记,对于询问我们二分然后取max即可,记得判断没有前驱的情况。

数列分块入门4

区间加,区间求和
维护加法标记然后维护块内的和即可,然后可以直接每次对于零散块重构,当然也可以不重构。

数列分块入门5

区间开方,区间求和
这是一个复杂度均摊的典型例子,首先区间开方最多进行O(loglogn)次,所以最多5次就会变成1,然后我们维护整块和,对于每次操作暴力开方直到整块都是1,可以发现每一块最多被暴力开方5次,所以复杂度有保证。

数列分块入门6

单点插入,单点查询
这是一个重构的典型例子,我们可以选择替罪羊重构也可以选择根号重构,然后每次插入到对应块,只需要O(n)O(\sqrt{n})O(n)找到对应块并O(n)O(\sqrt{n})O(n)处理对应块即可,查询类似。

数列分块入门7

区间加,区间乘,区间求和对一个数取模
一开始处理零散块有一个不用下放标记的想法,因为是取模不用担心精度问题,所以可以对零散块进行一定操作,但是0没有逆元,所以这个方法是不行的。
我们还是得对零散块暴力下放标记。

一定记得求解逆元时候保证逆元存在

数列分块入门8

区间查询多少个元素是c,并且区间推平为c
这种区间覆盖问题往往是需要复杂度均摊,这里我们可以用分块解决,维护标记,然后每次暴力查询,对于每次最多增加两个值不同的块,对于每个值不同的块需要花费O(n)O(\sqrt{n})O(n)的时间处理,所以总复杂度为O(nn)O(n\sqrt{n})O(nn)

数列分块入门9

经典区间众数问题
首先如果离线的话,莫队就可以做了,如果强制在线我们就使用分块处理,然后区间众数问题显然没法快速合并,但是我们利用分块可以预处理很多信息。

方法一:我们可以处理所有块和块之间的众数,维护每个数出现的位置,用一个vector储存,然后每次询问,答案必然是整块间的众数或者是零散块所有的数,数量级是O(n)O(\sqrt{n})O(n)的,直接暴力枚举,然后利用位置信息二分查找即可。

方法二:我们可以预处理块的前缀和,处理前缀块中每个数出现次数时空复杂度O(nn)O(n\sqrt{n})O(nn),之后可以O(1)O(1)O(1)查询一段块中某个数出现次数,然后处理块和块之间的众数,然后每次询问时候利用一个map处理前后零散块,遍历map,找到出现次数最多的即可。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/314355.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CF436F Banners(分块/凸包/单调队列)

CF436F Banners 首先有n个物品分别有ai和bi,然后定义价值为 c∗wp∗(ai大于p且bi小于c的用户个数)c*wp*(ai大于p且bi小于c的用户个数)c∗wp∗(ai大于p且bi小于c的用户个数) 然后我们需要求解对于每一个c的最大价值和对应的p 首先我们先枚举c,然后每次加…

译 | 改进 Visual Studio 及 Windows 上 .NET Core 的安装体验

点击上方蓝字关注“汪宇杰博客”原文:Lee Coward翻译:Edi Wang导语Visual Studio 2019 16.3 和 .NET Core 3.0 Preview 7 改进了 Windows 上 .NET Core 的安装体验。目标是减少计算机上可能存在的 .NET Core 版本的数量。这些改进基于客户反馈和我们自己…

F. Ivan and Burgers(前缀线性基模板)

前缀线性基模板 F. Ivan and Burgers /*Author : lifehappy */ #pragma GCC optimize(2) #pragma GCC optimize(3) #include <bits/stdc.h>#define mp make_pair #define pb push_back #define endl \n #define mid (l r >> 1) #define lson rt << 1, l, …

P2231 [HNOI2002]跳蚤(裴蜀定理/莫比乌斯反演)

P2231 [HNOI2002]跳蚤 给定一个长度为n1的一列数&#xff0c;第n1位为m&#xff0c;前n位小于m 求解使得他n1个数的加减可以凑出1的方案数 首先可以凑出1&#xff0c;这显然是裴蜀定理&#xff0c;推一推就发现他要求所有数的gcd为1 那么对于要求gcd恰为x的计数问题&#xff…

HDU 6579 Operation (前缀线性基模板题)

Operation 思路 只要套上前缀线性基的板子然后按照题意模拟即可&#xff0c;前缀线性基模板题了。 代码 /*Author : lifehappy */ #pragma GCC optimize(2) #pragma GCC optimize(3) #include <bits/stdc.h>#define mp make_pair #define pb push_back #define endl …

SonarQube系列三、Jenkins集成SonarQube(dotnetcore篇)

来源&#xff1a;https://www.cnblogs.com/7tiny/p/11348785.html【前言】本系列主要讲述sonarqube的安装部署以及如何集成jenkins自动化分析.netcore项目。目录如下&#xff1a;SonarQube系列一、Linux安装与部署SonarQube系列二、分析dotnet core/C#代码SonarQube系列三、Jen…

[2020多校A层11.22]party(概率期望/近似)

[2020多校A层11.22]party 非常巧妙的一个概率期望问题&#xff0c;其实运用的还是近似的思想 现在有n个物品&#xff0c;每次一个人有pi的概率选中这个物品&#xff0c;然后可以进行猜测&#xff0c;但是无论是否猜中都继续游戏&#xff0c;直到所有人都被猜中&#xff0c;求解…

E. Beautiful Subarrays(思维 01 trie 树)

E. Beautiful Subarrays 思路 显然有ai⨁ai1⨁……⨁an(a1⨁a2⨁……⨁an)⨁(a1⨁a2⨁……⨁ai−1)a_i\bigoplus a_{i 1} \bigoplus ……\bigoplus a_{n} (a_1 \bigoplus a_2 \bigoplus……\bigoplus a_{n}) \bigoplus (a_1 \bigoplus a_2 \bigoplus …… \bigoplus a_{i -…

CF198D Cube Snake(三维空间/增量构造)

CF198D Cube Snake n<50 显然是一个构造题&#xff0c;然后很容易想到增量构造&#xff0c;可以考虑每次保证一层值域连续&#xff0c;然后再增加一个值域连续的层&#xff0c;就会产生两个值域连续的正方体&#xff0c;但是只移动头是不够的&#xff0c;所以我们还需要移…

发布ABP v0.19包含Angular UI选项

ABP v0.19已发布,包含解决的~90个问题和600次提交.新功能Angular UI终于,ABP有了一个SPA UI选项,使用最新的Angular框架.Angular的集成不是简单地创建了一个启动模板.创建了一个基础架构来处理ABP的模块化,主题和其他一些功能.此基础结构已部署为NPM包.为帐户,身份和租户管理等…

P4151 [WC2011]最大XOR和路径(线性基应用)

P4151 [WC2011]最大XOR和路径 思路 如果单纯的只是树形图&#xff0c;那么答案显然易见只有一种&#xff0c;也就是从头到尾的路径从头到尾的异或值&#xff0c;但是这里不同的就是有可能在道路上有许多的环。 题目有一个重点提示的一句话 理解这句话之后那么我们可以显然…

CF603D Ruminations on Ruminants(计算几何/Simson theorem)

CF603D Ruminations on Ruminants 给定n条直线&#xff0c;两两不平行&#xff0c;且任意三条直线不经过同一个点&#xff0c;然后求解满足原点在外接圆上的由三条直线围成的三角形有多少个。 首先这道题只需要知道Simson theorem就可以做了。 定理内容是三角形外接圆上的点到…

Docker(一)-CentOS7中安装Docker视频教程

一、前言Docker的使用越来越多&#xff0c;安装也相对简单。本文使用视频的方式展示在CentOS7系统中安装Docker&#xff0c;本文更适合于准备入门学习Docker的童靴&#xff0c;同时也欢迎各路大神给我们指点提建议。二、环境CentOS7三、安装Docker确认Linux内核版本# uname -a卸…

P3292 [SCOI2016]幸运数字(树剖 + 线段树维护线性基)

P3292 [SCOI2016]幸运数字 思路 如果这题是求x,yx, yx,y之间的距离显然我们可以通过树剖加线段树来写&#xff0c; 但是这里变成了求任意个数的异或最大值。如果给定区间我们显然可以通过线性基来求解&#xff0c;但是这里是动态的区间&#xff0c;每次区间需要我们去找&…

CF773E Blog Post Rating(推导min的通项/线段树)

CF773E Blog Post Rating 现在有一个值F&#xff0c;每次如果序列加入一个数后重新排列&#xff0c;每次如果F小于期望值&#xff0c;就会1&#xff0c;如果等于就不变&#xff0c;如果大于就-1&#xff0c;求解每一次加入后F的最大值。 这道题的确是非常的巧妙&#xff0c;尤…

用Keras.NET 做一个图像识别的训练

.NET Core 的应用场景越来越广&#xff0c;开源社区也不断壮大&#xff0c; .NET Core在机器学习领域不断发展ML.NET外&#xff0c;也通过结合Tensorflow.NET去完善ML.NET在深度学习领域的功能&#xff0c;在ML.NET 1.3开始迈出了非常重要的一步。这不仅是微软拥抱开源的策略&a…

2019牛客多校第四场 B xor (线性基求交)

xor 思路 题目是要求[l,r][l, r][l,r]的所有集合是否都可以得到xxx&#xff0c;那么显然我们可以对这[l,r][l, r][l,r]个线性基求交&#xff0c;然后再特判能否xxx能否插入&#xff0c;如果能插入&#xff0c;显然输出NONONO&#xff0c;否则就输出YESYESYES&#xff0c;所以…

「数据ETL」从数据民工到数据白领蜕变之旅(六)-将Python的能力嫁接到SSIS中...

前一篇推文中&#xff0c;给大家演示了在SSIS上使用dotNET脚本&#xff0c;实现一些原生SSIS难以实现的功能&#xff0c;并冠以无限可能的说法。充分复用python的现有优势python的确是一门非常优秀的编程语言&#xff0c;特别是在数据领域&#xff0c;网络爬虫、数据处理、分析…

.NET Core玩转爬虫系列之借助正则表达式入门篇

接下来一段时间&#xff0c;我会花些时间研究C#玩转爬虫的方法及其实践。话不多说&#xff0c;开始吧~一般来说:设计并实现一个爬虫的步骤是:模拟登录 -> 模拟发送request请求 -> 取回response数据 -> 提取所需信息并将其进行重新组织 -> 存入DB或文件中 -> 后期…

单位根反演

单位根反演 https://www.cnblogs.com/cjyyb/p/10838495.html