Lyndon words

定义:

对于一个字符串\(S\),若\(S\)的最小后缀是其本身,则\(S\)为一个\(lyndon\)串;

记为\(S\in L\);

即:

\[S \in L
\begin{cases}
minsuf(S)=S\\
S为其本身的\mathbf{严格}最小循环
\end{cases}
\]

所以对于\(lyndon\ words\)有一个性质:

\[Border(S)=\varnothing
\]

否则就不满足定义;

推论:

\(if\quad u,v\in L\quad and\quad u<v\)

\(\quad then \quad uv\in L\)

证明:理性证明很难受,还是感性理解比较好,

ps:

  1. \(u'\)为\(u\)的子串;
  2. \(u\triangleright v\) :\(u\)严格比\(v\)小,且非前缀;
  3. \(u\sqsubseteq v\) :\(u\)为\(v\)的前缀;

按\(uv\)的后缀\(S\)分为三种情况:

  1. 当\(S=u'v\)时,

因为 \(u \triangleright u'\);

所以 \(uv\triangleright u'v\);

  1. \(S=v\) 时,

分为两种情况;

1)\(u\triangleright v\), 那么显然 \(uv<v\);

2)\(u\sqsubseteq v\),则\(v=uv'\)

​ 因为有\(v<v'\)

​ 所以\(uv<uv'\Rightarrow uv<v\) ;

  1. \(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)\);

\[CFL(S)=S_1,S_2...S_k
\begin{cases}
1. \quad S_i\in L\\
2. \quad S_1\ge S_2 \ge ...\ge S_k
\end{cases}
\]

此分解唯一;

性质:

  1. \(S_k\)为最长的\(Lyndon\ suffix\)
  2. \(S_1\)为最长的\(Lyndon\ prefix\)
  3. \(Sk=minsuf(S)\)

好的后面的就不怎么会了,(或者说我只会感性理解,不知道如何理性证明,口胡)

关于证明和求\(Lyndon\ Faetorization\)的\(Duval\)算法请参考:Lyndon相关——newbielyx

发现我经常套他博客(滑稽

Lyndon words学习笔记的更多相关文章

  1. Lyndon Word学习笔记

    Lyndon Word 定义:对于字符串\(s\),若\(s\)的最小后缀为其本身,那么称\(s\)为Lyndon串 等价性:\(s\)为Lyndon串等价于\(s\)本身是其循环移位中最小的一个 性 ...

  2. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  3. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  4. PHP-会员登录与注册例子解析-学习笔记

    1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...

  5. 2014年暑假c#学习笔记目录

    2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...

  6. JAVA GUI编程学习笔记目录

    2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...

  7. seaJs学习笔记2 – seaJs组建库的使用

    原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...

  8. CSS学习笔记

    CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...

  9. HTML学习笔记

    HTML学习笔记 2016年12月15日整理 Chapter1 URL(scheme://host.domain:port/path/filename) scheme: 定义因特网服务的类型,常见的为 ...

随机推荐

  1. 重温Java Web的技术细节

    目录 一.背景 二.请求与响应 2.1.Http请求 2.2.Http响应 三.ServletConfig 3.1 测试ServletConfig参数 四.ServletContext 4.1 测试S ...

  2. 【小白学PyTorch】1 搭建一个超简单的网络

    文章目录: 目录 1 任务 2 实现思路 3 实现过程 3.1 引入必要库 3.2 创建训练集 3.3 搭建网络 3.4 设置优化器 3.5 训练网络 3.6 测试 1 任务 首先说下我们要搭建的网络 ...

  3. How to avoid multiple definition of function with gcc

    LDFLAGS add -Wl,--allow-multiple-definition

  4. Visual Studio Installer闪退问题解决方法

    Visual Studio 2019安装推荐的方式是通过官方给的Installer进行的(2017也是同样方法),但是有时会出现在”即将完成…一切即将准备就绪“这个界面闪退的问题,导致软件的安装.卸载 ...

  5. 初学WebGL引擎-BabylonJS:第0篇-起因

    学习WebGL的BabylonJS是在一次偶然的情况下进行的,主要为了满足个人对全栈开发的欲望. 言归正传,下面开始简单说说相关过程 WebGL是什么?WebGL是基于html的客户端页面技术,基于h ...

  6. 透过UIRoot深入理解NGUI提供的屏幕适配方案

    主要代码:UIRoot,UIOrthoCamera,UIRect.GetSides(UIPanel使用UIRect的)里的GetSides,代码量很少,但需要思考和测试验证. 一.UIRoot的基本内 ...

  7. MySql密码的问题

    由于长时间没使用过MySql了,也由于之前没有做笔记的习惯,晚上因为MySQL的密码问题导致数据库长时间没连上.纠结了这么久还是决定记录下来,毕竟安装的东西多了,这年头到处都是密码,加上时间一长,很容 ...

  8. The Unique MST(最小生成树的唯一性判断)

    Given a connected undirected graph, tell if its minimum spanning tree is unique. Definition 1 (Spann ...

  9. 对于分布式Job的思考

    引言 在清理Github的时候,发现以前写的一个简单的分布式任务分发系统ClawHub/task-distribution,使用了zk的选主与队列,调度器使用spring的ThreadPoolTask ...

  10. HTML5 Drag & Drop

    一定要区分不同事件产生的对象 源元素 属性:draggable = "true" 事件: ondragstart:开始拖拽 ondragend:拖拽结束 目标元素 事件: ondr ...