根号算法

分块

数列分块入门九题(hzwer)

  • 入门题1,2,3,4,5,7

问题:给一段区间打上标记后单点查询

解法:主要是每块维护一些标记,计算答案等,此类分块较为简单

注意:块大小一般为\(\sqrt n\)

复杂度:\(O(n\sqrt n)\)

  • 入门题6

问题:每次朝数列中间插入一个元素,查询第k个元素是什么

解法:块大小超过一定值后暴力重构!采用链表实现

复杂度:\(O(n\sqrt n)\)

  • 入门题8

问题:每次询问一个区间内为\(c​\)的元素个数,并把整个区间改为\(c​\)

解法:维护一个区间覆盖标记,如果块内没有标记就暴力修改

注意:复杂度分析要用到FlashHu的势能分析

势能(potential energy)是储存于一个系统内的能量,也可以释放或者转化为其他形式的能量。

把一个块搅乱,相当于给其增加\(O(\sqrt n)\)的势能,表示其再次被打上全局tag所需要的代价

每次操作最多把两个块搅乱,所以每次操作最多增加\(O(2\sqrt n)\)的势能,同时整理好一个块需要的代价是其势能,并能把其势能降为\(O(1)\)

这样子最多搅乱\(n\)个块,增加\(O(2n\sqrt n)\)的势能,最多把他们所有的势能都变成\(1\),复杂度为\(O(4n\sqrt n)=O(n\sqrt n)\)

理解:增加势能需要相应代价,减少势能也需要相应代价,对应分析其最大势能即可得出复杂度

拓展:分析每次可以从栈中弹出多个元素的复杂度(还是\(O(n)\),其总势能最大为\(O(n)\))

  • 入门题9

问题:在线维护区间最小众数

解法:离线就可以用莫队搞了

考虑分块,分块是一个很好的算法,维护每个数在数列中的前缀和是\(O(n^2)\)的时空复杂度,但是给分个块就可以做到\(O(n\sqrt n)\)了

一段区间的众数一定属于:A.零散块内的数 B.整块内的众数,一共数量不超过\(\sqrt n\)个

所以维护两个数组:\(f[i][j]\)表示从第\(i\)块到第\(j\)块的众数,这个可以\(O(\sqrt n\sqrt n\sqrt n)\)的预处理出来;\(g[i][j]\)表示离散化后的数字\(i\)在前\(j\)块中出现的次数,这个可以\(O(n)\)赋值后\(O(n\sqrt n)\)统计前缀和而得到

之后便只需要:A.统计每个数在整块内的出现个数\(O(1×\sqrt n)\) B.统计零散块中的数\(O(\sqrt n)\)

综上,复杂度为\(O(n\sqrt n)\),完美通过此题/蒲公英

分块出过什么题

维护序列哈,支持一些在线的区间询问

  • 区间tag单点查询、区间查询等等老掉牙的套路(但是考场上遇到维护序列的题这也是一种思想方式

  • 询问位置\(\%p=k\)的数的权值和,要求支持单点修改,\(val\le 1W,n\le 15W\)(哈希冲突)

对于\(p\le\sqrt n\),维护\(s[p][k]\)表示答案,这个可以\(O(n\sqrt n)\)扫一遍得到答案

对于\(p>\sqrt n\),可以开\(s[i][1k]\)表示第i块的桶,统计前缀和,然后暴力对\(\sqrt n\)的桶扫一遍

综上,复杂度为\(O(n\sqrt n)\)

  • 求区间逆序对数,不修改,\(n\le 5W\)(Gty的妹子序列)

先预处理好\(s[i][j]\)表示从第\(i\)块的开头到\(j\)位置这一段区间产生的逆序对数,\(O(n\sqrt n logn)\)

然后查询时剩下的左半截用主席树暴力查询,\(O(n\sqrt nlogn)\)

  • 单点修改,求最短前缀使得前缀\(gcd\)与前缀\(xor\)的乘积恰好为\(x\),\(n\le 10W\)(公约数数列)

有一个奇妙的性质:一个数集的\(gcd\)在加入一个数后要么不变,要么至少\(/2\)。

对每一块维护一个gcd和、异或前缀和、Map(维护异或前缀和为x的位置)

然后修改就暴力重构该块\(O(n\sqrt nlogn)\)

查询就依次扫每一个块,如果这个块没有使得gcd减小,那么这个块内每一个位置的前缀gcd都相同,在Map中查找是否有符合条件的异或和即可;如果gcd减小了就暴力一个一个找,由于上面的性质暴力扫的块不会超过\(logn\)个。

总复杂度为\(O(n\sqrt nlogn)\)

  • 无修改询问区间内数值\(\%p=k\)的元素个数,\(n\le 15W\)(考试9.20T3)

若\(p\le\sqrt n\),对每块维护\(s[i][p][k]\)表示答案,然后边角暴力统计,\(O(n\sqrt n)\)

若\(p>\sqrt n\) ,对每块维护\(s[i][j]\)表示桶,然后做一个前缀和暴力查询,\(O(n\sqrt n)\)

简直傻逼我做不出真是太菜了

莫队

树莫队

有两种方法,一种是把树划分成若干块,然后暴力去移动其中一个端点;另一种是把树的欧拉序抠出来(像括号序列,每个点出现两次),转化为序列问题后再用序列莫队的方法。我学习的是拓展性更强的后者。两者都要用\(vis[i]\)表示i这个点选了没选,每次\(update\)就把\(vis[x]^=1\)

序列莫队

无修

对序列位置分块,每块大小为\(\sqrt n\),将询问离线,按照左端点所在块为第一关键字右端点为第二关键字排序,每次暴力移动转移,复杂度\(O(n\sqrt n)\)

带修

块大小为\(n^{\frac{2}{3}}\),按照左端点所在块为第一关键字,右端点所在块为第二关键字,操作时间为第三关键字排序(所有排序都是从小到大),复杂度\(O(n^{\frac{5}{3}})\)

分治

序列分治

一般适用于:一组询问,对象是所有子区间的问题

把区间分治成为跨过中点的区间和左右分治

点分治

  • 树上路径抠成序列后DP(有结合律),可以采用点分治实现(牛客Wannafly24C网址

    实现方式:把询问挂链,分治的时候,把分治区域的\(rt\)都设置为分治中心,同时给不同子树标个不同的\(Tag\)(同一子树相同)。每到一个结点便扫一遍询问,当询问的另一个点也在同样的分治区域,并且\(Tag\)不同,便计算贡献。

    这样能够保证不重不漏地计算所有的贡献,复杂度为\(O(nlogn*DP)\),为点分治×DP的复杂度(询问只会被扫log次)

倍增

并查集倍增

[SCOI2016]萌萌哒 对区间的每个点一一对应连并查集

Noip前的大抱佛脚----根号对数算法的更多相关文章

  1. Noip前的大抱佛脚----文章索引

    Noip前的大抱佛脚----赛前任务 Noip前的大抱佛脚----考场配置 Noip前的大抱佛脚----数论 Noip前的大抱佛脚----图论 Noip前的大抱佛脚----动态规划 Noip前的大抱佛 ...

  2. Noip前的大抱佛脚----Noip真题复习

    Noip前的大抱佛脚----Noip真题复习 Tags: Noip前的大抱佛脚 Noip2010 题目不难,但是三个半小时的话要写四道题还是需要码力,不过按照现在的实力应该不出意外可以AK的. 机器翻 ...

  3. Noip前的大抱佛脚----字符串

    目录 字符串 经验 用FFT求解字符串匹配问题 两(多)串DP时状态合并 最长公共子序列转LIS 位运算最大值 挂链哈希 哈希处理回文串 树哈希 字符串模板库 KMP 最小循环表示 Mancher A ...

  4. Noip前的大抱佛脚----数论

    目录 数论 知识点 Exgcd 逆元 gcd 欧拉函数\(\varphi(x)\) CRT&EXCRT BSGS&EXBSGS FFT/NTT/MTT/FWT 组合公式 斯特林数 卡塔 ...

  5. Noip前的大抱佛脚----图论

    目录 图论 知识点 二分图相关 DFS找环 并查集维护二分图 二分图匹配的不可行边 最小生成树相关 最短路树 最短路相关 负环 多源最短路 差分约束系统 01最短路 k短路 网络流 zkw费用流 做题 ...

  6. Noip前的大抱佛脚----数据结构

    目录 数据结构 知识点及其应用 线段树 神奇标记 标记不下放 并查集 维护二分图 维护后继位置 堆 可并堆的可持久化 dsu on tree 方式&原理 适用范围 单调队列 尺取合法区间 模板 ...

  7. Noip前的大抱佛脚----一些思路

    目录 一些思路 序列 函数问题 网格图 删除和询问 乘法问题 顺序问题 最值问题 研究成果 数论分块套数论分块的复杂度 一些思路 Tags:Noip前的大抱佛脚 序列 线段树(当然还要有主席树啊!) ...

  8. Noip前的大抱佛脚----赛前任务

    赛前任务 tags:任务清单 前言 现在xzy太弱了,而且他最近越来越弱了,天天被爆踩,天天被爆踩 题单不会在作业部落发布,所以可(yi)能(ding)会不及时更新 省选前的练习莫名其妙地成为了Noi ...

  9. Noip前的大抱佛脚----奇技淫巧

    STL函数 set set查找前驱后继 multiset<int>::iterator iter; S.insert(x); iter=S.find(x);//返回迭代器 iter--;/ ...

随机推荐

  1. Sql Server中的谓词和运算符

    谓词和运算符配合使用是我们得到理想数据的最佳途径. 一.浅谈谓词 谓词的概念:一个运算结果为True.False或Unknown的逻辑表达式.它的运用范围有:where子句.Having子句.Chec ...

  2. SpringMVC源码分析和一些常用最佳实践

    前言 本文分两部分,第一部分剖析SpringMVC的源代码,看看一个请求响应是如何处理,第二部分主要介绍一些使用中的最佳实践,这些best practices有些比较common,有些比较tricky ...

  3. 12.2Data Guard新特性--使用DBMS_DBCOMP.DBCOMP数据比较

          Oracle Data Guard会主动对Hot数据(数据正被读取或修改)执行验证, 无论是primary还是standby,但对于那些Cold数据不会做任何检查和校验.所以在12.2版本 ...

  4. django项目设计

    我们以前是只建立一个项目只建立一个app,如果我们要建立多个app的时候 并且这个app要写很多额视图的函数views内函数,要是建立很多种的时候就会造成很冗杂,不美观  我们未来增强解耦性,就把那个 ...

  5. 多线程应用-类(thread)

    在对class thread加锁时,锁无法正常应用,函数方式没问题. 在使用class thread方法时,并发后的查询结果不对,函数方式没问题. # -*- coding: UTF-8 -*- fr ...

  6. python常见释疑(有别于报错)(不定时更新)

    文:铁乐与猫 01.在cmd运行py脚本后,直接回到了提示符,没有任何输出,看起来像是并没有运行一样. 答:你的感觉很可能是对的,但脚本很可能己经正常运行,只是你的代码里面很可能没有给出print提示 ...

  7. Hadoop HBase概念学习系列之HBase的Shell(步骤非常清晰)(二十四)

    这部分知识点,是必须要熟练玩转的! 见 5 hbase-shell + hbase的java api 的进入HBase Shell   强烈建议,先看我上面的这篇博文,是实实际际的步骤. 另外,附上一 ...

  8. September 19th 2017 Week 38th Tuesday

    Live boldly. Push yourself. Don't settle. 勇敢生活,突破自我,永不设限! Don't indulge in the past, whether it was ...

  9. Civil War

    Civil War 编辑 <Civil War>是美国硬摇滚乐队枪炮与玫瑰的一首单曲,首次收录于1990年的群星慈善专辑<Nobody's Child: Romanian Angel ...

  10. randint(1,100) s.add(n) 集合的去重复性