知识点简单总结——Lyndon分解
知识点简单总结——Lyndon分解
Lyndon串
定义:一个字符串的最小后缀就是整个串本身。
等效理解:这个串为其所有循环表示中最小的。
Lyndon分解
定义:将字符串分割为 $ s_{1} s_{2} ... s_{k} $ 任意段使得每一段都是Lyndon串且 $ \forall i < j , s_{i} \ge s_{j} $ 。
引理一:若 $ u < v $ 且 $ u , v $ 均为Lyndon串,则 $ uv $ 为Lyndon串。
关于证明,它咕了。
引理二:Lyndon分解存在且唯一。
存在性:全部分成单个字符后利用引理一合并。
唯一性:假设存在两种Lyndon分解分别为
$ s_1 s_2 ... s_{i} s_{i+1} ... $
$ s_1 s_2 ... s_{i} ' s_{i+1} ' ... $
不妨设 $ | s_{i} | > | s_{i} ' | , s_{i} = s_{i} ' s_{i+1} ' ... s_{k} ' [ 1...l ] $ , 其中 $ s_{k} ' [ 1...l ] $ 为这这一部分串的非空前缀。
有 $ s_{i} < s_{k} ' [ 1...k ] \le s_{k} ' \le s_{i} ' < s_{i} $ ,矛盾。
引理三:若有字符串 $ v $ ,字符$ c , d $ , $ d > c $ ,且 $ vc $ 为一个Lyndon串的前缀,则有 $ vd $ 为Lyndon串。
关于证明,它也咕了。
求Lyndon分解
可以用单调栈或者后缀数组啥的,但是复杂度不够好。
Duval算法
维护三个指针 $ i,j,k $
表示 $ s [ 1 , i - 1 ] $ 已经划分完了
$ s [ i , k - 1 ] $ 是一个Lyndon串 $ t $ 的周期循环 $ t^{g} + v $ ( $ v $ 是 $ t $ 的前缀)周期 $ t = k - j $ ,且保证 $ s [ i , k - 1 ] $ 小于前面已经划分好的串。
分情况讨论:
$ s[k] == s[j] $ :周期不变, $ j++ , k++ $ 。
$ s[k] > s[j] $ :根据引理三可知 $ v + s[k] $ 是Lyndon串,向前合并使得 $ s[i,k] $ 变成新的Lyndon循环节, $ j=i , k++ $ 。
$ s[k] < s[j] $ :将循环节逐个固定成划分结果。
以下是洛谷P6114 【模板】Lyndon 分解的代码。
#include<bits/stdc++.h>
using namespace std;
namespace RKK
{
char s[5000011];int n;
int prt[5000011],pc;
int main()
{
scanf("%s",s+1),n=strlen(s+1);
int i=1,j,k,ans=0;while(i<=n)
{
for(j=i,k=i+1;k<=n&&s[k]>=s[j];k++) s[k]>s[j]?j=i:j++;
while(i<=j) ans^=i+k-j-1,prt[++pc]=i+k-j-1,i+=k-j;
}
printf("%d\n",ans);
// for(int i=1;i<=pc;i++) printf("%d ",prt[i]);putchar('\n');
return 0;
}
}
int main(){return RKK::main();}
应用:
我基本没看到过用Lyndon分解的题。
随便来一个:CF594E Cutting the Line
知识点简单总结——Lyndon分解的更多相关文章
- 知识点简单总结——Pollard-Rho算法
知识点简单总结--Pollard-Rho算法 MillerRabin算法 用于对较大(int64)范围内的数判定质数. 原理:费马小定理,二次探测定理. 二次探测定理:若 $ p $ 为奇素数且 $ ...
- LOJ129 Lyndon 分解
Lyndon 分解 样例 样例输入 1 ababa 样例输出 1 2 4 5 样例输入 2 bbababaabaaabaaaab 样例输出 2 1 2 4 6 9 13 18 样例输入 3 azAZ0 ...
- HDU - 6761 Minimum Index (字符串,Lyndon分解)
Minimum Index 题意 求字符串所有前缀的所有后缀表示中字典序最小的位置集合,最终转换为1112进制表示.比如aab,有三个前缀分别为a,aa,aab.其中a的后缀只有一个a,位置下标1:a ...
- 知识点简单总结——FWT(快速沃尔什变换),FST(快速子集变换)
知识点简单总结--FWT(快速沃尔什变换),FST(快速子集变换) 闲话 博客园的markdown也太傻逼了吧. 快速沃尔什变换 位运算卷积 形如 $ f[ i ] = \sum\limits_{ j ...
- 知识点简单总结——minmax容斥
知识点简单总结--minmax容斥 minmax容斥 好像也有个叫法叫最值反演? 就是这样的一个柿子: \[max(S) = \sum\limits_{ T \subseteq S } min(T) ...
- 知识点简单总结——BSGS与EXBSGS
知识点简单总结--BSGS与EXBSGS BSGS 给出 $ A,B,C,(A,C)=1 $ ,要你求最小的 $ x $ ,使得 $ A^x \equiv B(mod \ C) $ . 在数论题中经常 ...
- XPath知识点简单总结(思维导图)
XPath是一种用于在XML文档中查找信息的语言,其对HTML也有很好的支持,所以在网络爬虫中可用于解析HTML文档.参考链接. 下图是XPath知识点的简单总结成思维导图:
- nginx知识点简单回顾
html { font-family: sans-serif } body { margin: 0 } article,aside,details,figcaption,figure,footer,h ...
- lua语言自学知识点----简单了解
零碎知识点: lua:用lua写UI,更新UI,因为lua可直接跨平台解析,不需要编译,方便更新------>热更新. c#反射也可以达到更新,但非常麻烦,切不支持iOS. 在lua中一个人汉字 ...
随机推荐
- BugKu-Misc-简单取证1
下载文件压缩包,解压得到文件夹config,根据题目得知为取证,使用工具mimikatz, github地址:https://github.com/ParrotSec/mimikatz 将文件夹con ...
- Wireshark教程之数据包操作
实验目的 1.工具介绍 2.主要应用 实验原理 1.网络管理员用来解决网络问题 2.网络安全工程师用来检测安全隐患 3.开发人员用来测试执行情况 4.学习网络协议 实验内容 1.工具基本使用 2.快速 ...
- jar工具常用命令
参考链接:https://www.ibm.com/developerworks/cn/java/j-jar/index.html
- dbeaver安装配置
安装出现库依赖没有,可以添加maven仓库 修改字体:小四
- idea maven: invalid class root
maven导入依赖没有问题,但是项目lib的类飘红,实际导入的类中有一些没有,这是idea的问题,重启idea,发现需要重新导入项目,重新导入后问题解决. 原因:可能之前误删了项目中idea的一些文件 ...
- 无法打开备份设备,出现操作系统错误 5(拒绝访问)(sql server备份)
问题:无法打开备份设备 .出现操作系统错误 5(拒绝访问) 原因:你用sqlserver进行备份的时候,必须要是完整的路径,操作sqlserver的和磁盘有关的路径都必须要到文件名这一层. 解决方案: ...
- shell脚本的调试sh-x
转至:https://blog.csdn.net/yjgithub/article/details/80908079 目录 一.简介 二.sh -x 脚本名.sh 三.set -x 一.简介 使用sh ...
- DirectX11 With Windows SDK--36 延迟渲染基础
前言 随着图形硬件变得越来越通用和可编程化,采用实时3D图形渲染的应用程序已经开始探索传统渲染管线的替代方案,以避免其缺点.其中一项最流行的技术就是所谓的延迟渲染.这项技术主要是为了支持大量的动态灯光 ...
- matplotlib补充知识及数据清理方法
今日内容概要 数据操作 数据清洗理论 数据清洗实操 数据操作 read_csv read_excel read_hdf read_html read_json read_msgpack read_sq ...
- Web应用程序自动化测试工具Selenium的主要功能有哪些?
Selenium是一个用于Web应用程序测试的工具.是一个开源的Web的自动化测试工具,最初是为网站自动化测试而开发的,类型像我们玩游戏用的按键精灵,可以按指定的命令自动操作,不同是Selenium可 ...