知识点简单总结——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分解的更多相关文章

  1. 知识点简单总结——Pollard-Rho算法

    知识点简单总结--Pollard-Rho算法 MillerRabin算法 用于对较大(int64)范围内的数判定质数. 原理:费马小定理,二次探测定理. 二次探测定理:若 $ p $ 为奇素数且 $ ...

  2. LOJ129 Lyndon 分解

    Lyndon 分解 样例 样例输入 1 ababa 样例输出 1 2 4 5 样例输入 2 bbababaabaaabaaaab 样例输出 2 1 2 4 6 9 13 18 样例输入 3 azAZ0 ...

  3. HDU - 6761 Minimum Index (字符串,Lyndon分解)

    Minimum Index 题意 求字符串所有前缀的所有后缀表示中字典序最小的位置集合,最终转换为1112进制表示.比如aab,有三个前缀分别为a,aa,aab.其中a的后缀只有一个a,位置下标1:a ...

  4. 知识点简单总结——FWT(快速沃尔什变换),FST(快速子集变换)

    知识点简单总结--FWT(快速沃尔什变换),FST(快速子集变换) 闲话 博客园的markdown也太傻逼了吧. 快速沃尔什变换 位运算卷积 形如 $ f[ i ] = \sum\limits_{ j ...

  5. 知识点简单总结——minmax容斥

    知识点简单总结--minmax容斥 minmax容斥 好像也有个叫法叫最值反演? 就是这样的一个柿子: \[max(S) = \sum\limits_{ T \subseteq S } min(T) ...

  6. 知识点简单总结——BSGS与EXBSGS

    知识点简单总结--BSGS与EXBSGS BSGS 给出 $ A,B,C,(A,C)=1 $ ,要你求最小的 $ x $ ,使得 $ A^x \equiv B(mod \ C) $ . 在数论题中经常 ...

  7. XPath知识点简单总结(思维导图)

    XPath是一种用于在XML文档中查找信息的语言,其对HTML也有很好的支持,所以在网络爬虫中可用于解析HTML文档.参考链接. 下图是XPath知识点的简单总结成思维导图:

  8. nginx知识点简单回顾

    html { font-family: sans-serif } body { margin: 0 } article,aside,details,figcaption,figure,footer,h ...

  9. lua语言自学知识点----简单了解

    零碎知识点: lua:用lua写UI,更新UI,因为lua可直接跨平台解析,不需要编译,方便更新------>热更新. c#反射也可以达到更新,但非常麻烦,切不支持iOS. 在lua中一个人汉字 ...

随机推荐

  1. redis(二)-----redis基本数据类型之字符串

    Redis的全称是REmote Dictionary Server,它主要提供了5种数据结构:字符串.哈希.列表.集合.有序集合,同时在字符串的基础之上演变 出了位图(Bitmaps)和HyperLo ...

  2. kafka3.x原理详解看这篇就够了

    一.概述 (一).kafka的定义 1.定义 1)kafka传统的定义:kafka是一个分布式的基于发布/订阅模式的消息队列,主要用于大数据实时处理领域 2)kafka最新的定义:kafka是一个开源 ...

  3. 018 磁盘 IO 性能监控/压测工具(sar、iotop、fio、iostat)

    1 sar 命令查看当前磁盘 IO 读写 sar(System Activity Reporter 系统活动情况报告)是 Linux 上最为全面的系统性能分析工具之一,可以从多方面对系统的活动进行报告 ...

  4. vscode分栏显示快捷键

    vscode没有默认的分栏快捷键,我们可以自定义,步骤如下: 1.Crtl + k,再Ctrl + s,调出快捷键设置面板 2.在搜索栏输入"视图:",在未定义快捷键的区域找到&q ...

  5. [题解]UVA658 It's not a Bug, it's a Feature!

    链接:http://vjudge.net/problem/viewProblem.action?id=22169 描述:有n个漏洞,m个修复漏洞的方法,每种方法耗时不一样,求修复漏洞的最短时间.每种方 ...

  6. 不需要高价购买BI工具,掌握这个Excel插件就能碾压大数据

    ​曾几何时,EXCEL在数据界可谓是独树一帜,引领风骚,在职场中无人不知,无人不晓.但是随着大数据的出现,EXCEL便风光不再,江河日下,一度被其他大数据工具挤到了后面,逐渐被边缘化了.而我是一个EX ...

  7. 基于mysql的报表工具有哪些?值得推荐的mysql报表工具

    什么是SQL?SQL是结构化查询语言. 什么是数据库?数据库是用来存储数据的. 什么是mysql?Mysql是目前较为流行的数据库. 基于mysql的报表工具有哪些? 其实现在所有的报表工具,基本都支 ...

  8. 记一次阿里云oss文件上传服务假死

    引言 记得以前刚开始学习web项目的时候,经常涉及到需要上传图片啥的,那时候都是把图片上传到当前项目文件夹下面,每次项目一重启图片就丢了.虽然可以通过修改/tomcat/conf/server.xml ...

  9. 【C# 并发编程】开端

    1,异步编程 异步编程就是使用future模式(又称promise)或者回调机制来实现(Non-blocking on waiting). 如果使用回调或事件来实现(容易callback hell), ...

  10. 《Java从入门到精通》学习笔记(详细)

    目录 03 Java语言基础 基本数据类型 变量与常量 运算符 类型转换 代码规范 标识符命名规范 常用输入输出 04 流程控制 条件语句 循环语句 循环控制 练习 05 字符串 创建字符串 连接字符 ...