| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1351 人关注过本帖, 1 人收藏
标题:关于KMP算法的理念
只看楼主 加入收藏
aizuoai123
Rank: 2
等 级:论坛游民
帖 子:44
专家分:36
注 册:2010-5-14
结帖率:100%
收藏(1)
已结贴  问题点数:20 回复次数:9 
关于KMP算法的理念
小菜我反复看了KMP算法的思想要义
但是还是没办法理解
希望大神们能通俗易懂的阐述一下KMP算法的思想(源代码我有).
搜索更多相关主题的帖子: KMP 算法 理念 
2010-08-03 12:56
hzh512
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:6
帖 子:234
专家分:1333
注 册:2009-6-5
收藏
得分:19 
你先了解一下朴素的模式匹配算法。
KMP算法是基于朴素的算法并去掉了回溯,所以效率变得很高。

不知道你了解到什么程度:
1. 朴素的模式匹配算法会带有回溯,这种现象你是否理解?
2. KMP的匹配过程,你是否了解?

编程=用几种语言在某个或几个平台上通过抽象思维运用一系列算法来解决现实中问题的手段
2010-08-03 14:36
朱涛
Rank: 2
等 级:论坛游民
帖 子:6
专家分:15
注 册:2010-7-30
收藏
得分:1 
如果说是串A去匹配串B,普通的匹配速度慢因为它在匹配的某个位置的时候如果失败了,那么要A往后平移一个,从第一个字符开始重新匹配。而kmp可以往后平移更多的位,并且不需要从第一位重新开始,可以直接从某一个k位开始匹配(保证移动后前面已经是相同的了)
感觉没说清楚,凑活看吧

当做必做,坚持完成
2010-08-03 16:03
aizuoai123
Rank: 2
等 级:论坛游民
帖 子:44
专家分:36
注 册:2010-5-14
收藏
得分:0 
我只知道简单匹配法,是带有回溯的 不知道是不是你所说的朴素的模式匹配。
我所说的简单匹配法就是一直匹配到不相等然后回到主串与模式串匹配时主串的后一个开始与模式串匹配
KMP的过程  我是了解一点
麻烦你讲一下KMP怎么去掉回溯的
其实书上的内容我有看过几遍了
但是还是不能理解吃透
所以想找一个通俗易懂的方法理解
2010-08-03 16:13
aizuoai123
Rank: 2
等 级:论坛游民
帖 子:44
专家分:36
注 册:2010-5-14
收藏
得分:0 
以下是引用朱涛在2010-8-3 16:03:22的发言:

如果说是串A去匹配串B,普通的匹配速度慢因为它在匹配的某个位置的时候如果失败了,那么要A往后平移一个,从第一个字符开始重新匹配。而kmp可以往后平移更多的位,并且不需要从第一位重新开始,可以直接从某一个k位开始匹配(保证移动后前面已经是相同的了)
感觉没说清楚,凑活看吧
因为我看过KMP的大概思路 你说的我看的明白
但是那个保证易懂后前面的是相同的这个代码能说说明白点么
2010-08-03 16:16
hzh512
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:6
帖 子:234
专家分:1333
注 册:2009-6-5
收藏
得分:0 
举个例子:

Target:  acabaabaabcacaabc
Pattern: abaabcac

Step1:
T: a c a b a a b a a b c a c a a b c
P: a b a a b c a c

Step2:
T: a c a b a a b a a b c a c a a b c
P:     a b a a b c a c

Step3:               
T: a c a b a a b | a a b c a c a a b c
P:     a b a a b | c a c

Step1 - Step3 与朴素匹配无差别,关键Step4
显然,如果用朴素匹配方法
a b a a  !=  b a a b           ------必然失配
a b a  !=  a a b  -----------必然失配
a b  ==  a b   -----------有匹配的可能

Step4:
T: a c a b a a b a a b c a c a a b c
P:           a b a a b c a c

从这里你可以看出,此次KMP匹配省掉了两次必然失配的匹配过程。

总之,关键是找出Pattern的特征函数
下面举例来说明如何求一个pattern的next特征函数
Pattern:a b a a b c a c
令 j 表示失配的位置。例如,j = 0 ,即在第0位(Pattern的a处)发生失配。
现在开始计算:
j = 0 :next(j) = -1, 表示一开始就发生失配,target向右移一位,Pattern从0开始。
j = 1:next(j) = 0, 表示其他情况,target保持不动, Pattern从0开始
j = 2:next(j) = 0, 表示其他情况,target保持不动, Pattern从0开始
j = 3:next(j) = 1, 表示前面1位(a)= 后面1位(a),target保持不变,Pattern从1开始匹配。
j = 4:next(j) = 1, 表示前面1位(a)= 后面1位(a),target保持不变,Pattern从1开始匹配。
j = 5:next(j) = 2, 表示前面2位(ab)= 后面2位(ab),target保持不变,Pattern从2开始匹配。

也即,从头开始并同时从尾开始比较,看看头尾有多少连续的位相同

关键是明白模式的next特征函数,其他都很简单。

[ 本帖最后由 hzh512 于 2010-8-3 16:40 编辑 ]

编程=用几种语言在某个或几个平台上通过抽象思维运用一系列算法来解决现实中问题的手段
2010-08-03 16:34
aizuoai123
Rank: 2
等 级:论坛游民
帖 子:44
专家分:36
注 册:2010-5-14
收藏
得分:0 
恩 对的
就是对这个特征NEXT函数  
不是太理解
2010-08-03 17:41
hzh512
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:6
帖 子:234
专家分:1333
注 册:2009-6-5
收藏
得分:0 
你可以想一下为什么“从头开始并同时从尾开始比较,看看头尾有多少连续的位相同,其数目就是next的值”,其实在匹配中,用到next函数的地方,都是已经匹配好的部分,也就是说target和Pattern在这部分是完全相同的,然后你再想一下为什么要求头和尾相同的数目(因为当>2时,Pattern这时要跳跃)

编程=用几种语言在某个或几个平台上通过抽象思维运用一系列算法来解决现实中问题的手段
2010-08-03 18:06
aizuoai123
Rank: 2
等 级:论坛游民
帖 子:44
专家分:36
注 册:2010-5-14
收藏
得分:0 
谢谢啊
有点理解了
2010-08-03 18:06
hzh512
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:6
帖 子:234
专家分:1333
注 册:2009-6-5
收藏
得分:0 

编程=用几种语言在某个或几个平台上通过抽象思维运用一系列算法来解决现实中问题的手段
2010-08-04 10:55
快速回复:关于KMP算法的理念
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.020742 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved