数据结构 静态查找表、KMP算法复习

KMP算法说明

从目标字符串str中看是否有和子字符串ptr一样的部分。一般匹配字符串时,我们从目标字符串str(假设长度为n)的第一个下标选取和ptr长度(长度为m)一样的子字符串进行比较,如果一样,就返回开始处的下标值,不一样,选取str下一个下标,同样选取长度为n的字符串进行比较,直到str的末尾(实际比较时,下标移动到n-m)。这样的时间复杂度是O(n*m)。

KMP算法:可以实现复杂度为O(m+n)

为何简化了时间复杂度:
充分利用了目标字符串ptr的性质(比如里面部分字符串的重复性,即使不存在重复字段,在比较时,实现最大的移动量)。


一、求解next值(重点是与要求的next值的前一位的值相等即可

步骤:next数组值的程序设计求解方法:

  • 首先可以肯定的是第一位的next值为0,第二位的next值为1
  • 后面求解每一位的next值时,根据前一位进行比较。
  • 首先将前一位与其next值对应的内容进行比较
  1. 如果相等,则该位的next值就是前一位的next值加上1;
  2. 如果不等,向前继续寻找next值对应的内容来与前一位进行比较,直到找到某个位上内容的next值对应的内容与前一位相等为止,则这个位对应的值加上1即为需求的next值;
  3. 如果找到第一位都没有找到与前一位相等的内容,那么需求的位上的next值即为1。

举例:

求串′ababaaababaa′的next数组
模式串    a    b    a    b    a    a    a    b    a    b    a    a
下标       1    2    3    4    5    6    7    8    9    10  11  12

1、前两位:next数组前两位规定是0,1 即前两位ab对应的next数组为01,则:
模式串    a    b    a    b    a    a    a    b    a    b    a    a
下标       1    2    3    4    5    6    7    8    9    10  11   12
next        0    1                                                  

2、接下来看第三位,按照next数组求解方法。第三位a的前一位为第二位的b,b的next值为1对应内容为a,b与a不同,向前继续寻找next值对应的内容来与前一位进行比较。因为找到第一位都没有找到与前一位相等的内容,所以第三位a的next值为1,则:
模式串    a    b    a    b    a    a    a    b    a    b    a    a
下标       1    2    3    4    5    6    7    8    9    10  11  12
next       0    1    1                                             

3、接下来看第四位b,b的前一位a的next值1对应内容为a,相同,所以该位b的next值就是前一位a的next值加上1,即为2
模式串    a    b    a    b    a    a    a    b    a    b    a    a
下标       1    2    3    4    5    6    7    8    9    10  11   12
next       0    1    1    2                                        

4、接下来看第五位a,a的前一位b的next值2对应内容为b,相等,所以该位a的next值就是前一位b的next值加上1,即为3
模式串    a    b    a    b    a    a    a    b    a    b    a    a
下标       1    2    3    4    5    6    7    8    9    10  11   12
next       0    1    1    2    3                                   

5、接下来看第六位a,a的前一位a的next值3对应内容为a,相等,所以该位a的next值就是前一位a的next值加上1,即为4
模式串    a    b    a    b    a    a    a    b    a    b    a    a
下标       1    2    3    4    5    6    7    8    9    10  11   12
next       0    1    1    2    3    4                              

6、接下来看第七位a,a的前一位a的next值4对应内容为b,不相等,向前继续寻找next值对应的内容来与前一位进行比较,b的next值2对应的内容为b,依旧不相等,继续向前寻找,第二位b的next值1对应内容为a,相等。因为是在第二位b处实现的相等,所以第七位a的next值为第二位b的next值上加1,即为2
模式串    a    b    a    b    a    a    a    b    a    b    a    a
下标       1    2    3    4    5    6    7    8    9    10    11    12
next       0    1    1    2    3    4    2                         

7、接下来看第八位,同样道理,得出b的next值为2
模式串    a    b    a    b    a    a    a    b    a    b    a    a
下标       1    2    3    4    5    6    7    8    9    10  11   12
next       0    1    1    2    3    4    2    2                    

8、接下来看第九位,前一位b的next值2对应内容为b,相等,所以此处next值为3
模式串    a    b    a    b    a    a    a    b    a    b    a    a
下标       1    2    3    4    5    6    7    8    9    10  11   12
next       0    1    1    2    3    4    2    2    3               

9、第十位同理可得,为4
模式串    a    b    a    b    a    a    a    b    a    b    a    a
下标      1    2    3    4    5    6    7    8    9    10  11   12
next      0    1    1    2    3    4    2    2    3     4          

10、第十一位a的前一位b的next值4对应内容为b,相等,所以此处next值为5
模式串    a    b    a    b    a    a    a    b    a    b    a    a
下标       1    2    3    4    5    6    7    8    9    10  11   12
next       0    1    1    2    3    4    2    2    3     4    5     

11、最后,第十二位同理可以得到next值为6
模式串    a    b    a    b    a    a    a    b    a    b    a    a
下标       1    2    3    4    5    6    7    8    9    10  11   12
next       0    1    1    2    3    4    2    2    3      4   5     6

二、求解nextval(不同则自己,相同则找到底的别人

步骤:nextval数组值的程序设计求解方法:

  • 第一位的nextval的值必为0
  • 第二位与第一位进行比较
  1. 如果是一样的字母的话,第二位的nextval为第一位next所对应的值
  2. 如果不是一样的字母的话,第二位的nextval为自身的next值
  • 从第三位开始,每个都要与自己next值对应的位置的字母进行比较
  1. 如果是一样的字母的话,那么继续向前面找next对应值与此位的字母是否相同,直到找到最头上没有与其相等的数为止,这里的nextval为最后一个相等字母对应的next值
  2. 如果不是一样的字母的话,这里的nextval为自身的next值

举例:

   模式串       a b a a b c a c

      位置      1 2 3 4 5 6 7 8

  next值      0 1 1 2 2 3 1 2

  nextval值   0 1 0 2 1 3 0 2



  1.第一位的nextval值必定为0,第二位如果于第一位相同则为0,如果不同则为1。

  2.第三位的next值为1,那么将第三位和第一位进行比较,均为a,相同,则,第三位的nextval值为0。

  3.第四位的next值为2,那么将第四位和第二位进行比较,不同,则第四位的nextval值为其next值,为2。

  4.第五位的next值为2,那么将第五位和第二位进行比较,相同,第二位的next值为1,则继续将第二位与第一位进行比较,不同,则第五位的nextval值为第二位的next值,为1。

  5.第六位的next值为3,那么将第六位和第三位进行比较,不同,则第六位的nextval值为其next值,为3。

  6.第七位的next值为1,那么将第七位和第一位进行比较,相同,则第七位的nextval值为0。

  7.第八位的next值为2,那么将第八位和第二位进行比较,不同,则第八位的nextval值为其next值,为2。

1、


2、


3、


4、


5、


6、

答案:F


7、

答案:D

解析:

6%11=6;

25%11=3;

39%11=6,有冲突;6+1方=7,无冲突;

61%11=6,有冲突;6+1方=7,有冲突;6-1方=5,无冲突,所以放在5的位置;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值