数据结构(十一)串

一、ADT

定义

数据结构(十一)串_第1张图片

 

 术语

数据结构(十一)串_第2张图片

 

ADT

数据结构(十一)串_第3张图片

 

 b1串匹配

数据结构(十一)串_第4张图片

数据结构(十一)串_第5张图片

 

 

算法评测

数据结构(十一)串_第6张图片

 

 

b2 蛮力匹配

数据结构(十一)串_第7张图片

 

 版本一

数据结构(十一)串_第8张图片

 

 版本2

数据结构(十一)串_第9张图片

 

 

复杂度

 数据结构(十一)串_第10张图片

 

 数据结构(十一)串_第11张图片

 

 数据结构(十一)串_第12张图片

 

 

 

c1KMP算法:从记忆力到预知力

蛮力,为何低效

数据结构(十一)串_第13张图片

 

 

很多比对不必进行

 

 

不变性

数据结构(十一)串_第14张图片

 

 

只要记忆力足够强

数据结构(十一)串_第15张图片

 

 

记忆力转为预知力

 

c2KMP算法:查询表

事先确定t

数据结构(十一)串_第16张图片

 

 算法

数据结构(十一)串_第17张图片

 

 

实例

模式串,下面是对应的查询表,倒数第三个字符秩为j=7,查询表中next值为3

数据结构(十一)串_第18张图片

 

 主串,如果轮到这个表项发挥作用,说明当前这轮比对中,此前七个字符都是成功的

 

 即此时的场景是如下,即模式串中的字符l,与文本串中某个不是l的字符比对失败

数据结构(十一)串_第19张图片

 

比对之前为模式串拍一个快照

 

 手动执行KMP算法,当前j=7,指向模式串中的字符l,接下来,KMP将在查询表中取出对应的那一项next[7},并用它来更新j,这个表项是3,接下来会用秩为3的字符,也就是n取代l,并继续与文本串中此前失配的字符对齐,就像这样:

 数据结构(十一)串_第20张图片

 

为模式串再拍一张快照:

 

 

 前后两张快照,模式串向右移动了4个字符,KMP排除了三个对齐位置

 

 

c3 KMP算法:理解next[]表

 

自匹配=快速右移

借助必要条件,排除对齐位置

数据结构(十一)串_第21张图片

 

 

最长自匹配=快速右移+避免回退

 

Next[0]==1

数据结构(十一)串_第22张图片

 

 巧妙地使用哨兵,可以简化代码,统一理解

 

 

c4 KMP算法:构造next[]表

递推

数据结构(十一)串_第23张图片

数据结构(十一)串_第24张图片

 

 

实现

数据结构(十一)串_第25张图片

 

 

c5 KMP算法:分摊分析

数据结构(十一)串_第26张图片

 

 

c6 KMP算法:再改进

反例

数据结构(十一)串_第27张图片

 

 改进

数据结构(十一)串_第28张图片

 

 

失败情况:Brute-force

失败情况:KMP

 

多个字符对多个字符

d1 BM算法:坏字符

 

善待教训

更多地关注教训,使之更早地出现,更大者更早出现

 

前轻后重

 

以终为始

数据结构(十一)串_第29张图片

 

 Bad-Character

数据结构(十一)串_第30张图片

 

 

构造bc[]表

数据结构(十一)串_第31张图片

 

 

最好情况

数据结构(十一)串_第32张图片

 

最差情况

 利用好了教训,没有很好的利用经验

数据结构(十一)串_第33张图片

 

 

e1 BM_GS算法:好后缀

经验=匹配的后缀

 

 

good suffix shift

数据结构(十一)串_第34张图片

 

 

实例

数据结构(十一)串_第35张图片

 

 

e2 BM_GS算法:构造gs表

MS[]->ss[]

数据结构(十一)串_第36张图片

 

 

 

ss[]->gs[]

数据结构(十一)串_第37张图片

 

 

 构造ss[]

数据结构(十一)串_第38张图片

 

 

 

 

e3 BM_GS算法:综合性能

性能

数据结构(十一)串_第39张图片

 

 数据结构(十一)串_第40张图片

 

 

纵览

数据结构(十一)串_第41张图片

 

 

 

f1 Karp-Rabin算法:串即是数

数据结构(十一)串_第42张图片

 

 凡物皆数

数据结构(十一)串_第43张图片

 

 数据结构(十一)串_第44张图片

 

 

串亦为数

数据结构(十一)串_第45张图片

 

 

f2 Karp-Rabin算法:散列

数位溢出

数据结构(十一)串_第46张图片

 

 

散列压缩

数据结构(十一)串_第47张图片

 

 散列冲突

数据结构(十一)串_第48张图片

 

 快速指纹计算

数据结构(十一)串_第49张图片

 

转载于:https://www.cnblogs.com/aidata/p/11584445.html

你可能感兴趣的:(数据结构与算法)