洛谷题单

后缀数组

前置芝士

后缀数组 1

后缀数组 2

后缀数组 3

例题略解

P2463 [SDOI2008]Sandy的卡片

板子题。。。

然而我还是不会。

大概做法就是先把所有的串差分后拼成一个大的串,小的串之间用一个极大数(比差分数组中最大的数大就可以)隔开。

并且确保每个用于隔开小串的数大小不同,每隔开一个\(+1\)就可以了。

然后进行二分答案就\(OK\)了

\(code\)

P2336 [SCOI2012]喵星球上的点名

SA+莫队

大概就是像上一个题一样,将所有的名字建成一个大串,记录一下所在名字,

然后对于每个询问预处理一下在SA数组左右的端点

之后的做法和莫队就是标准的莫队了。。。

\(code\)

P4094 [HEOI2016/TJOI2016]字符串

正解:主席树+SA+二分+RMQ

但是暴力做法远快于正解,而且码量思路也比较好想

还是那个推论2,对于以a到b开始的每个后缀都求一下,

然后在把推算结果与d-c+1取最小值。

  • 对于a到b中rk小于rk[c]的:

    从rk[c]开始,到height[i]小于ans就停止,如果i大于sa[a]小于sa[b]更新就好了
  • 对于a到b中rk等于rk[c]的:

    特判一下
  • 对于a到b中rk大于rk[c]的:

    把小于rk[c]的操作从rk[c]+1到n进行一边就好了

\(code\)

P4248 [AHOI2013]差异

单调栈+SA求LCP

比较易懂,大概就是先把题面上的式子简化一下,

变成某个带n的代数式加上LCP

\(∀1\leq i<j\leq n,\) \(LCP(sa_i,sa_j)=\min\limits_{i< k\leq j} (height_k)\)

然后运用LCP的推论2,将问题转化成了求每个子区间的最小值的加和

可以打权值线段树,但是太麻烦了,于是可以用单调栈来优化

  • 注意:

    在求SA时M所赋的初值应大于原序列中的最大值

\(code\)

BZOJ3230

SA+RMQ(ST表)+二分

每个字串都是一个后缀的前缀,先求一下SA以及LCP,

然后就可以预处理出每个后缀的左右边界值

在处理询问的时候进行二分,查看要查询的字串的左右端点在哪两个后缀中,

最后算一下就好了

  • 注意:

    对于每一个操作都要搞正反两遍

\(code\)

P2178 [NOI2015] 品酒大会

常规做法是并查集+SA(+set)

但是zxb用三棵线段树硬是给干过去了,做法么,和差异这个题差不多,tql%%%

用RMQ暴力有两种打法:

  • 最简单的也是得分最低的:

    每种情况都枚举一遍
  • 优化的暴力:对于不同的LCP都更新,然后累加

正解就是对于第二种暴力放弃RMQ,改用并查集维护,处理一个siz值,对于不同的点进行合并,这里用set维护了一下并查集

  • 注意:因为有负值,因此们要求max(最大值 * 次大值,最小值 * 次小值)

\(code\)

\(manacher\)

前置芝士

\(manacher\)

例题略解

P4287 [SHOI2011]双倍回文

半个板子题,有一个很妙的思路,在处理manacher的时候整一下,对于i=1的情况,循环一下i+p[i],如果j-i长度为4的倍数,更新答案。

毕竟,双倍的回文串还要计算上在每一位之间插进去的字符。


荣登最优解\(Top3\)


  • 注意:i&3表示 \(i\mod4\) ,同样的,i&7可以表示\(i\mod8\)

\(code\)

P4555 [国家集训队]最长双回文串

我真傻,真的,我单知道输入字符串从0开始,却不知道求manachar时也要从0开始处理

和上一题差不多,都是在manachar函数里搞事情

开一个l和r数组用来表示以i为分割点的所谓双回文串的左右端点,理论上来讲,l在最后取max时应该从n到2,r应该从2到n,防止更改过的对以后的有影响。但是数据他水呀

最后取一下\(l[i]+r[i]\)的最值就ok了

\(code\)

P3501 [POI2010]ANT-Antisymmetry

SP15569 STC02 - Antisymmetry

还是在manachar的板子上进行修改。

观察题面,无非就是要求我们求异或意义下的回文串

因为题面的意思是要求我们1与0相对,而不是1与1相对,在函数里循环的时候两个两个的枚举防止#与#判等的情况,相对关系用一个to数组存就好了。

在一个长度为\(L\)的异或回文串里共有\(\frac L2\)个异或回文串,直接加起来就好了。

\(code\)

P2601 [ZJOI2009]对称的正方形

正解和暴力都想了挺长时间,尤其是暴力\(code\)

用了离散化,regster int,inline来优化。

对于正解,就是对于整个方块横着竖着各扫一边,统计出横纵最长回文串的长度,在运算的时候可以用单调队列优化。

\(code\)

后缀数组&manachar总结的更多相关文章

  1. 后缀数组的倍增算法(Prefix Doubling)

    后缀数组的倍增算法(Prefix Doubling) 文本内容除特殊注明外,均在知识共享署名-非商业性使用-相同方式共享 3.0协议下提供,附加条款亦可能应用. 最近在自学习BWT算法(Burrows ...

  2. BZOJ 4199: [Noi2015]品酒大会 [后缀数组 带权并查集]

    4199: [Noi2015]品酒大会 UOJ:http://uoj.ac/problem/131 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战两个环节,分别向优胜者颁发“首席品 ...

  3. BZOJ 1692: [Usaco2007 Dec]队列变换 [后缀数组 贪心]

    1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1383  Solved: 582[Submit][St ...

  4. POJ3693 Maximum repetition substring [后缀数组 ST表]

    Maximum repetition substring Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9458   Acc ...

  5. POJ1743 Musical Theme [后缀数组]

    Musical Theme Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 27539   Accepted: 9290 De ...

  6. 后缀数组(suffix array)详解

    写在前面 在字符串处理当中,后缀树和后缀数组都是非常有力的工具. 其中后缀树大家了解得比较多,关于后缀数组则很少见于国内的资料. 其实后缀数组是后缀树的一个非常精巧的替代品,它比后缀树容易编程实现, ...

  7. 【UOJ #35】后缀排序 后缀数组模板

    http://uoj.ac/problem/35 以前做后缀数组的题直接粘模板...现在重新写一下模板 注意用来基数排序的数组一定要开到N. #include<cstdio> #inclu ...

  8. 【BZOJ-2119】股市的预测 后缀数组

    2119: 股市的预测 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 334  Solved: 154[Submit][Status][Discuss ...

  9. 【BZOJ-4698】Sandy的卡片 后缀数组

    4698: Sdoi2008 Sandy的卡片 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 140  Solved: 55[Submit][Stat ...

随机推荐

  1. OJ最大值最小化问题(分发书本)

    该类问题通用描述: 有n个物体,每个物体都有一个权值V[i],现在将n个物体连续分成m个部分,m个部分有一个部分会拿到最多的权值v.求所有分配方式中最小的v. 典型题目: 分发书本,宠物屋涂色等. 问 ...

  2. Codeforces Round #697 (Div. 3)

    A.Odd Divisor 题意:问一个数是不是含有奇数因子 思路:就直接给这个数循环除以2,看看最后剩下的数是不是0,如果不是就有奇数因子,如果是就没有 想不到:1)当时想着用log2来解决问题,后 ...

  3. MzzTxx——团队贡献分分配方案

    项目 内容 这个作业属于哪个课程 2021春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 团队贡献分分配规则制定 我在这个课程的目标是 进一步提升工程化开发能力,积累团队协作经验,熟悉全栈 ...

  4. [Python] execl读写

    相关库 读:xlrd 写:xlwt 案例 要求: 将图1中的数据导以图2的形式写入另一个文件中 第一列索引关系:{1:K1-B1,2:K1-B2} ...(18列) 思路: 按行读取数据,根据索引关系 ...

  5. [BD] HBase

    NoSQL数据库 关系型数据库:用表格的行-列来保存数据,OLTP,写入多,行式存储 非关系型数据库:只用来存储数据,业务逻辑由应用程序处理,OLAP,查询多,列式存储 常见NoSQL数据库 Redi ...

  6. iozone测试方法-20191008

    iozone   一.简介 磁盘设备之上是文件系统,测试磁盘的工具往往就是调用驱动块设备驱动的接口进行读写测试.而文件系统的测试软件就是,针对文件系统层提供的功能进行测试,包括文件的打开关闭速度以及顺 ...

  7. Linux软件安装管理之——dpkg与apt-*详解 apt命令(dpkg和apt代替rpm)

    apt list *python* Nosee123关注赞赏支持   Linux软件安装管理之--dpkg与apt-*详解 [Linux软件安装管理系列]- - 传送门: - -<Linux软件 ...

  8. dstat命令

    dstat命令 dstat命令是一个用来替换vmstat.iostat.netstat.nfsstat和ifstat这些命令的工具,是一个全能系统信息统计工具.与sysstat相比,dstat拥有一个 ...

  9. 2019年又迎来Hi1620,鲲鹏920则是Hi1620系列的正式品牌和型号

    据记者了解,2013年华为就发布了Hi1610,2014年的Hi1612是ARM64位CPU,2016年的Hi1616是首颗支持多路的ARM处理器,2019年又迎来Hi1620,鲲鹏920则是Hi16 ...

  10. C++知识点案例 笔记-1

    1.重载函数 2.内联函数 3.New.Delete 4.重载与.const形参 5.常数据成员 6.静态成员函数 ==重载函数== #include <iostream> using n ...