设正文串长度为n,模式串长度为m,则模式匹配的KMP算法的时间复杂度为()
A.O(m*n)
B.O(n)
C.O(m)
D.O(m+n)
第1题:
●在字符串的模式匹配过程中,如果模式串的每个字符依次和主事中一个连续的字符序列相等,则称为匹配成功。如果不能在主串中找到与模式串相同的子串,则称为匹配失败。在布鲁特—福斯模式匹配算法(朴素的或基本的模式匹配)中,若主串和模式串的长度分别为n和m(且n远大于m),且恰好在主串末尾的m个字符处匹配成功,则在上述的模式匹配过程中,字符的比较次数最多为(57)。
(57) A. n*m
B. (n-m+1)*m
C. (n-m-1)*m
D. (n-m)*n
第2题:
●在KMP模式匹配算法中,需要求解模式串p的next函数值,其定义如下(其中,j为模式串中字符的序号)。对于模式串“abaabaca”,其next函数值序列为(57)。

(57)
A. 01111111
B.01122341
C.01234567
D.01122334
第3题:
● 在字符串的模式匹配过程中,如果模式串的每个字符依次和主事中一个连续的字符序列相等,则称为匹配成功。如果不能在主串中找到与模式串相同的子串,则称为匹配失败。在布鲁特—福斯模式匹配算法(朴素的或基本的模式匹配)中,若主串和模式串的长度分别为n和m(且n远大于m),且恰好在主串末尾的m个字符处匹配成功,则在上述的模式匹配过程中,字符的比较次数最多为(57)。 A.n*m B.(n-m+1)*m C.(n-m-1)*m D.(n-m)*n
第4题:
在字符串的KMP模式匹配算法中,需先求解模式串的next函数值,其定义如下式所示,j表示模式串中字符的序号(从1开始)。若模式串p为“abaac”,则其next函数值为 (60) 。

A.01234
B.01122
C.01211
D.01111
第5题:

第6题:
设主串为“ABcCDABcdEFaBc”,以下模式串能与主串成功匹配的是()。
ABCd
BBcd
CAbc
DABC
第7题:
KMP模式匹配算法的改进之处是()。
第8题:
两个字符串S1和S2的长度分别为m和n,求这两个字符串最大共同子串的时间复杂度为T(m,n),这最优的时间复杂度为()。
第9题:
第10题:
O(m)
O(n)
O(m*n)
O(nlog2m)
第11题:
n
n(n+1)
n(n+1)/2
n(n+1)/2+1
第12题:
主串指针不需要回溯
模式串的指针来回移动
主串的指针也会回到之前比较过的字符
时间复杂度可以达到O(nm)
第13题:
第14题:
设主串长为n,模式串长为m(m≤n),则在匹配失败情况下,朴素匹配算法进行的无效位移次数为 ( )
A.m
B.n-m
C.n-m+1
D.n
第15题:
若目标串的长度为n,模式串的长度为[n/3],则执行模式匹配算法时,在最坏情况下的时间复杂度是( )。
A.O(1)
B.O(n)
C.O(n2)
D.0(n3)
第16题:
第17题:
第18题:
KMP算法的特点是在模式匹配时指示主串的指针不会回溯。
第19题:
若n为主串长,m为子串长,则串的古典(朴素)匹配算法最坏的情况下需要比较字符的总次数为()。
第20题:
长度为n的串s1与长度为2n的串s2的比较运算的时间复杂度是()。
第21题:
O(1)
O(n)
O(m)
O(m+n)
第22题:
对
错
第23题:
第24题: