对KMP算法通过代码生成next数组理解
本文是根据考研数据结构2019版天勤高分笔记理解编写的:
首先给出代码:
1 void getnext(Str substr,int next[]){
2 int i=0,j=0;
3 next[1]<=0;
4 while(i<substr.length){
5 if(j==0 || substr.ch[i]==substr.ch[j]){ //俩种情况会导致j==0。a,给串第一个元素的next[1]赋值时j默认为0 b,当模式串和主串不匹配时,j回溯到next[1]=0
//当前元素和已经匹配的串(正在延伸的前缀)的下一个元素进行比较,相等就继续延伸,否则j进行回溯,第10行(需要明白next的作用)
6 ++i;++j;
7 next[i]=j; //j表示0-j-1的前缀和后面一部分的子串已经匹配成功
8 }
9 else{
10 j=next[j]; //j回溯
11 }
12 }
13 }
数组pre和数组p一致,即next[j]代表已匹配前缀串pre的下标 如:j=5就代表已匹配的前缀ADAB的下标1,2,3,4
当j=5时,ch[11]!=ch[5],此时,退而其次,在已匹配的串"ADAB"中寻找能匹配D的元素。
而next数组的作用就是当模式串中第j个字符发生不匹配时,应从next[j]处的字符开始重新与主串比较。所以j回溯的时候用的是j=next[j];
只是:为什么next能起这样的作用呢?给个串对照一下:

这里我只把上面那部分的串的4位置和10位置的B改成了A,next数组只有next[5]由1变成了2.
现在讲讲我自己的理解:1,回退的过程中不仅2位置要和11位置想对应,2位置之前的所有位置(虽然这里只有一个元素)都必须和11位置前的响应元素一一对应,而next数组就代表前面有多个字符和前缀匹配成功。
2,正如前面所说的,数组pre和数组p一致,即next[j]代表已匹配前缀串pre的下标 ,,为什么改next【5】是2,对应了2(下标)位置的D,因为4位置的A和前缀A匹配。
=》保证俩个元素比较前,前缀和 j 位置前的对应长度的串是相等的(也就 是next的作用)
c和D不匹配ADAA这个前缀串的前缀是A,回溯到j=2,此时是保证了2(因为举例较简单,所以前缀只有一个元素,但我们可以把2位置发散成n位置)位置前所有的前缀(2-1 即n-1)个元素是和C元素前(2-1 即n-1)个元素匹配成功的;
而"ADAAC"和"ADAAD"中的"ADAA"的元素是匹配成功的,所以保证了ch【2-1】=ch【5-1】=ch【11-1】同样,这里的ch虽然只是一个字符,但也可以发散成一个串。
3,如果没有符合要求的子串,j必定回溯到1.
小编也是花了一整天根据自己对书本的理解,如果大家有什么不明白还请耐心点,kmp需要时间来理解!
对KMP算法通过代码生成next数组理解的更多相关文章
- KMP 算法中的 next 数组
KMP 算法中对 next 数组的理解 next 数组的意义 此处 next[j] = k:则有 k 前面的浅蓝色区域和 j 前面的浅蓝色区域相同: next[j] 表示当位置 j 的字符串与主串不匹 ...
- 字符串模式匹配之KMP算法图解与 next 数组原理和实现方案
之前说到,朴素的匹配,每趟比较,都要回溯主串的指针,费事.则 KMP 就是对朴素匹配的一种改进.正好复习一下. KMP 算法其改进思想在于: 每当一趟匹配过程中出现字符比较不相等时,不需要回溯主串的 ...
- KMP算法中next函数的理解
首先要感谢http://blog.csdn.net/v_july_v/article/details/7041827以及http://blog.chinaunix.net/uid-27164517-i ...
- (收藏)KMP算法的前缀next数组最通俗的解释
我们在一个母字符串中查找一个子字符串有很多方法.KMP是一种最常见的改进算法,它可以在匹配过程中失配的情况下,有效地多往后面跳几个字符,加快匹配速度. 当然我们可以看到这个算法针对的是子串有对称属性, ...
- KMP算法中求next数组的实质
在串匹配模式中,KMP算法较蛮力法是高效的算法,我觉得其中最重要的一点就是求next数组: 看了很多资料才弄明白求next数组是怎么求的,我发现我的忘性真的比记性大很多,每次看到KMP算法求next数 ...
- kmp算法中的next数组实例解释
假设求串′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数组前两位一 ...
- KMP算法中的next数组求解示意图
- 数据结构KMP算法中手算next数组
总结一下今天的收获(以王道数据结构书上的为例子,虽然我没看它上面的...):其中竖着的一列值是模式串前缀和后缀最长公共前缀. 最后求得的结果符合书上的结果,如果是以-1开头的话就不需要再加1,如果是以 ...
- KMP算法中我对获取next数组的理解
之前在学KMP算法时一直理解不了获取next数组的函数是如何实现的,现在大概知道怎么一回事了,记录一下我对获取next数组的理解. KMP算法实现的原理就不再赘述了,先上KMP代码: 1 void g ...
随机推荐
- 【HDU3394】Railway
[题目描述] 有一个公园有n个景点,公园的管理员准备修建m条道路,并且安排一些形成回路的参观路线.如果一条道路被多条道路公用,那么这条路是冲突的:如果一条道路没在任何一个回路内,那么这条路是不冲突的 ...
- Composert 的命令
(1) php artisan ----查看所有的命令帮助 (2) php artisan make:controller StudentController ----创建一个控 ...
- Bootstrap 中的 aria-label 和 aria-labelledby 属性
这两个属性是为特殊网页阅读器设置的属性,在一些特殊设备上,当浏览到这样的内容设备会将内容读出来.是为了一些有视力障碍的人能够同样”浏览”网页而准备的. 转自http://blog.csdn.net/l ...
- python 输入参数解包,模块导入,接收IO输入参数
#coding=utf-8 from sys import argv script,first,second,third = argv print "the script is=" ...
- Python读取CSV文件,报错:UnicodeDecodeError: 'gbk' codec can't decode byte 0xa7 in position 727: illegal multibyte sequence
Python读取CSV文件,报错:UnicodeDecodeError: 'gbk' codec can't decode byte 0xa7 in position 727: illegal mul ...
- mybatis的执行流程 #{}和${} Mysql自增主键返回 resultMap 一对多 多对一配置
n Mybatis配置 全局配置文件SqlMapConfig.xml,配置了Mybatis的运行环境等信息. Mapper.xml文件即Sql映射文件,文件中配置了操作数据库的Sql语句.此文件需要在 ...
- dpdk中kni模块
一,什么是kni,为什么要有kni Kni(Kernel NIC Interface)内核网卡接口,是DPDK允许用户态和内核态交换报文的解决方案,模拟了一个虚拟的网口,提供dpdk的应用程序和lin ...
- jQuery--后台主机列表编辑
先看效果: 要求: 全选,反选和取消 编辑模式下的全选,反选和取消 编辑模式下单选进入编辑状态,取消退出编辑状态 表格元素有可编辑,不可编辑,下拉选择 按住ctrl选择下拉框,下面的同列选项都随之改变 ...
- zigbee--绑定
1.绑定是zigbee一种基本通信方式:具体绑定通信又分为3种模式,在这里只拿一种源绑定来说明. 源绑定: 发送模块 :必须要知道接收模块(被绑定模块)的网络地址或者MAC地址 接收方的接收端点 接收 ...
- Part4_lesson1---Bootloader设计蓝图
1.bootloader的作用 2.u-boot是bootloader业界的老大 u-boot分为自主模式和开发模式 3.建立U-boot工程 uboot不能在window下面进行解压,因为在wind ...
