离散化一下然后把姓名串和询问串都放一起做SA 和bzoj3277串类似地,满足某一询问的后缀(就是和这个询问对应的后缀的LCP>=这个询问长度的后缀)的排名也是一个区间,把这个区间二分出来即可 现在要做的两个问题就变成了: 给定一些区间.一些点,每个点有对应的颜色(就是sa[i]对应的那个姓名串对应的人),问 1.每个区间中不同颜色的数量:同HH的项链 2.每个颜色被不同区间覆盖的数量: 想法其实和1是类似的,扫到区间左端点的时候给a[i]++,扫到右端点的时候给a[对应左端点]--,然后每个点…
题面 戳这里 题解 首先先把所有给出的姓名和询问全部接在一起,建出\(height\)数组. 某个串要包含整个询问串,其实就相当于某个串与询问串的\(lcp\)为询问串的长度. 而两个后缀\(Suffix_i\)和\(Suffix_j\)的\(lcp\)为\(min(height_{rank_i+1},height_{rank_i+2},...,height_{rank_j})\). 所以和某个询问串的\(lcp==\)询问串的长度的后缀的\(rank\)肯定是连续的(往两边拓展\(Min\)肯…
吐槽: 为啥很多人用AC自动机暴力跳都过了?复杂度真的对么? 做法一: AC自动机+树状数组 姓名的问题,中间加个特殊字符连起来即可. 肯定是对点名串建AC自动机(map存儿子),然后第一问就相当于问每个姓名串(以下称作"关键路径")经过了多少个点名串(以下称做"关键点")在fail树中的子树中的至少一点,第二问就相当于问你每条关键路径被多少个关键点经过了在fail树的子树中至少一个点. 所以对于每个关键路径在AC自动机上跑,每跑到一个点把它到根的路径上打上标记(注…
题目传送门(内部题98) 输入格式 第一行一个整数$n$,第二行$n$个整数$a_1\sim a_n$,第三行$n$个整数$b_1\sim b_n$. 输出格式 一行一个整数表示$\max(r-l+1)$.保证至少有一个区间满足条件. 样例 样例输入: 52 -4 1 2 -2-2 3 1 -3 1 样例输出: 数据范围与提示 对于$20\%$的数据,$n\leqslant 5,000$. 对于$60\%$的数据,$n\leqslant 10^5$. 对于$100\%$的数据,$1\leqsla…
用一个树状数组维护前缀和,每次我二分地找一个位置,使得我能一路买过去 但这个买不了 那以后肯定也都买不了了,就把它改成0,再从头二分地找下一个位置,直到这一圈我可以跑下来 然后就看跑这一圈要花多少钱.能买多少糖,拿T除一除,减一减,再去跑下一圈 每个位置只会被删一次,所以复杂度是$O(nlog^2n)$的 但那个用树状数组再二分的过程 其实大概可以在线段树上分治来做到一个log,但我哪会啊 #include<bits/stdc++.h> #define pa pair<int,int&g…
原文链接https://www.cnblogs.com/zhouzhendong/p/ARC101D.html 题目传送门 - ARC101D 题意 给定一个序列 A . 定义一个序列 A 的中位数为:给 A 排序,得到的第 $\left\lfloor\cfrac{i}{2}\right\rfloor+1$ 项的值. 序列 B 由序列 A 的所有连续子序列的中位数构成. 问序列 B 的中位数是多少. 序列中可能出现重复的数,$|A| \leq 10^5$ . 题解 注意这里说的“中位数”是题意里…
[题目大意] 给出一个长度为n的序列和m组查询(i,j,k),输出[i,j]中的第k大数. [思路] 先离散化然后莫队分块.用树状数组来维护当前每个值的个数,然后对于每次询问二分答案即可. 又一次实力写错二分…(生无可恋脸.jpg) #include<iostream> #include<cstdio> #include<cstring> #include<algorithm> #include<cmath> using namespace st…
为何感觉SHOI的题好水. ..又是一道SB题 从左到右枚举每个区间,遇到一个扇形的左区间就+1.遇到右区间就-1,然后再树状数组上2分答案,还是不会码log的.. SHOI2013似乎另一道题发牌也是相似的维护方法.. #include<algorithm> #include<iostream> #include<cstdlib> #include<cstring> #include<cstdio> #include<vector>…
传送门 一道很套路的题目 先将所有串拼在一起,两个不同的串之间放一个没有出现在任何串中的字符做分隔,然后SA 那么对于所有点名串能够点到的名字串在SA中对应一段区间 把这些区间拿出来然后莫队统计每一个区间的答案 如何在莫队中统计一个名字在多少个点名串中出现? 当某一个名字第一次出现在区间内的时候,答案加上剩余询问个数:当这个名字第一次不出现在区间内的时候,答案减去剩余询问个数. #include<bits/stdc++.h> //This code is written by Itst usi…
[BZOJ2754][SCOI2012]喵星球上的点名 题面 bzoj 洛谷 题解 这题有各种神仙做法啊,什么暴力\(AC\)自动机.\(SAM\)等等五花八门 我这个蒟蒻在这里提供一种复杂度正确且常数小的做法. 根据后缀数组经典套路, 我们用一个未出现过的字符将所有串连接起来求一边\(SA\)(不算询问串) 然后因为我们现在已经将所有后缀排好序了 而询问串要有贡献一定是一个后缀的前缀 所以一个区间能产生贡献的后缀是排名连续的一段 这样这段区间的左右端点可以二分出来 我们再对于每个位置记一下它是…