Lyndon words学习笔记
Lyndon words
定义:
对于一个字符串\(S\),若\(S\)的最小后缀是其本身,则\(S\)为一个\(lyndon\)串;
记为\(S\in L\);
即:
\begin{cases}
minsuf(S)=S\\
S为其本身的\mathbf{严格}最小循环
\end{cases}
\]
所以对于\(lyndon\ words\)有一个性质:
\]
否则就不满足定义;
推论:
\(if\quad u,v\in L\quad and\quad u<v\)
\(\quad then \quad uv\in L\)
证明:理性证明很难受,还是感性理解比较好,
ps:
- \(u'\)为\(u\)的子串;
- \(u\triangleright v\) :\(u\)严格比\(v\)小,且非前缀;
- \(u\sqsubseteq v\) :\(u\)为\(v\)的前缀;
按\(uv\)的后缀\(S\)分为三种情况:
- 当\(S=u'v\)时,
因为 \(u \triangleright u'\);
所以 \(uv\triangleright u'v\);
- \(S=v\) 时,
分为两种情况;
1)\(u\triangleright v\), 那么显然 \(uv<v\);
2)\(u\sqsubseteq v\),则\(v=uv'\)
因为有\(v<v'\)
所以\(uv<uv'\Rightarrow uv<v\) ;
- \(S=v'\)时,
有\(uv<v<v'\);
综上,对于三种情况都有\(uv<S\);
故\(uv\in L\);
证毕.
这样的话,就可以再推导出\(u^av^b\in L\);
(ps:\(u^a\not\in L\))
\(Lyndon\)分解(\(Lyndon\ Faetorization\))
定义:
对于一个串的\(Lyndon\ Faetorization\)记为\(CFL(S)\);
则
\begin{cases}
1. \quad S_i\in L\\
2. \quad S_1\ge S_2 \ge ...\ge S_k
\end{cases}
\]
此分解唯一;
性质:
- \(S_k\)为最长的\(Lyndon\ suffix\)
- \(S_1\)为最长的\(Lyndon\ prefix\)
- \(Sk=minsuf(S)\)
好的后面的就不怎么会了,(或者说我只会感性理解,不知道如何理性证明,口胡)
关于证明和求\(Lyndon\ Faetorization\)的\(Duval\)算法请参考:Lyndon相关——newbielyx
发现我经常套他博客(滑稽
Lyndon words学习笔记的更多相关文章
- Lyndon Word学习笔记
Lyndon Word 定义:对于字符串\(s\),若\(s\)的最小后缀为其本身,那么称\(s\)为Lyndon串 等价性:\(s\)为Lyndon串等价于\(s\)本身是其循环移位中最小的一个 性 ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- PHP-自定义模板-学习笔记
1. 开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2. 整体架构图 ...
- PHP-会员登录与注册例子解析-学习笔记
1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...
- 2014年暑假c#学习笔记目录
2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...
- JAVA GUI编程学习笔记目录
2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...
- seaJs学习笔记2 – seaJs组建库的使用
原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...
- CSS学习笔记
CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...
- HTML学习笔记
HTML学习笔记 2016年12月15日整理 Chapter1 URL(scheme://host.domain:port/path/filename) scheme: 定义因特网服务的类型,常见的为 ...
随机推荐
- oracle备份之恢复管理目录
一.管理恢复目录 #现实应用中一般都是专门新建一个rman 数据库,给所有的数据库做catalog1.建立恢复目录 #建立恢复目录表空间SQL> create tablespace rman_t ...
- PJSIP开发指南
一.通用设计 1.1 架构 1.1.1 通信图 下面的图展示了SIP消息在PJSIP组件间从后端到前端如何传递的. 1.1.2 类图 下面的图显示类视图 1.2 E ...
- ArcGIS Pro 二次开发
本文基于 Windows7 + VS2019 + .NET Framework 4.8 + ArcGIS Pro 2.5.22081 开发和撰写. 目录 开发环境配置 获取ArcGIS Pro 安装V ...
- IO优化
Linux性能优化之CPU.内存.IO优化 https://blog.csdn.net/zyc88888/article/details/79027944 iOS的I/O操作 https://www. ...
- HashMap位运算你可知一二
前置位运算知识 我们平时在写代码过程中用的位运算操作比较少,因为我们更关注于可读性而不是性能,如果为了性能而使用较多的位运算,我想我们的同事会疯掉.但在框架里位运算却非常常见,因为框架的性能是我们关注 ...
- Pandas | Dataframe的merge操作,像数据库一样尽情join
今天是pandas数据处理第8篇文章,我们一起来聊聊dataframe的合并. 常见的数据合并操作主要有两种,第一种是我们新生成了新的特征,想要把它和旧的特征合并在一起.第二种是我们新获取了一份数据集 ...
- 9.深入k8s:调度器及其源码分析
转载请声明出处哦~,本篇文章发布于luozhiyun的博客:https://www.luozhiyun.com 源码版本是1.19 这次讲解的是k8s的调度器部分的代码,相对来说比较复杂,慢慢的梳理清 ...
- 转载: Nginx 通览
转载地址:https://developer.51cto.com/art/201912/608365.htm Nginx 简介 Nginx 是一个免费.开源.高性能.轻量级的 HTTP 和反向代理服务 ...
- TomcatAJP文件包含漏洞
漏洞概述 2020年2月20日,国家信息安全漏洞共享平台(CNVD)发布关于Apache Tomcat的安全公告,Apache Tomcat文件包含漏洞(CNVD-2020-10487,对应CVE-2 ...
- MySQL的事务机制和锁(InnoDB引擎、MVCC多版本并发控制技术)
一.事务(数据库的事务都通用的定义) 1.1 事务定义 事务是由一步或几步数据库操作序列组成逻辑执行单元,这系列操作要么全部执行,要么全部放弃执行.事务通常以 BEGIN TRANSACTION 开始 ...