数据结构–字符串的朴素模式匹配算法
主串:
\color{purple}主串:
主串:
‘嘿嘿嘿红红火火恍恍惚惚嗨皮开森猴开森
笑出猪叫
\color{red}笑出猪叫
笑出猪叫哈哈哈哈嗨森哈哈哈哈哈哈嗝’
模式串:
\color{purple}模式串:
模式串:
‘笑出猪叫’
\color{red}‘笑出猪叫’
‘笑出猪叫’
子串
−
−
主串的一部分,一定存在
\color{pink}子串--主串的一部分,一定存在
子串−−主串的一部分,一定存在
模式串
−
−
不一定能在主串中找到
\color{pink}模式串--不一定能在主串中找到
模式串−−不一定能在主串中找到
两种模式匹配算法
data:image/s3,"s3://crabby-images/2fbec/2fbec1969a9d14bd40f3e4a495a8d17f0d613ea0" alt=""
朴素模式匹配算法
data:image/s3,"s3://crabby-images/cc822/cc822ba6e55e5e16fb49b51be2a700bae420555d" alt=""
data:image/s3,"s3://crabby-images/a7874/a78746f77c3dc9f7bf2152b734179fc094c2c86f" alt=""
… …
data:image/s3,"s3://crabby-images/9fb45/9fb45669154898ad65542a5dcee5eeb07b89ef33" alt=""
… …
data:image/s3,"s3://crabby-images/ab07d/ab07d8624cc657730ddca3983360a26aa7c3c706" alt=""
主串长度为n,模式串长度为m
最多对比
n
−
m
+
1
个子串
\color{red}最多对比n-m+1个子串
最多对比n−m+1个子串
朴素模式匹配算法︰将主串中
所有长度为
m
的子串
\color{red}所有长度为m的子串
所有长度为m的子串依次与模式串对比,直到找到一个完全匹配的子串,或所有的子串都不匹配为止。
data:image/s3,"s3://crabby-images/83d4e/83d4ed97984caa7f37450a180fd2a10c0e3c6326" alt=""
typedef struct
{
char ch[15];
int length;
}SString;
int Index(SString S, SString T)
{
int i = 1, j = 1;
while (i <= S.length && j <= T.length)
{
if (S.ch[i] == T.ch[j]) i++, j++;
else i = i - j + 2, j = 1;
}
if (j > T.length)
return i - T.length;
else
return 0;
}
时间复杂度
最坏时间复杂度= O(nm)
data:image/s3,"s3://crabby-images/134f3/134f3d07d1c0adcc26f1a56914aec0b23ab919b3" alt=""
最坏的情况,每个子串都要对比
m
m
m 个字符,共
n
−
m
+
1
n-m+1
n−m+1 个子串,复杂度=
O
(
(
n
−
m
+
1
)
m
)
=
O
(
n
m
)
O((n-m+1)m)= O(nm)
O((n−m+1)m)=O(nm)
注:很多时候,n >> m
知识点回顾与重要考点
data:image/s3,"s3://crabby-images/aebc2/aebc24307d77557bf55b5d60a6c7fb7231880f9d" alt=""