简单讲解KMP单模式匹配与AC算法多模式匹配(KMP篇)

本文简单讲解KMP单模式匹配算法,重点在于理解KMP的核心思想——比过的字符串不比了,并详细解释了next表的含义和作用。通过逻辑和思考方式,帮助读者掌握模式匹配的算法,降低理解难度。
摘要由CSDN通过智能技术生成

前言

本篇是对于KMP单模式匹配以及AC算法多模式匹配的简单讲解,KMP算法与AC算法是关键字检索中的常见算法,能够快速而高效地查找出目标字符串中的多个关键字的匹配情况,而要检索的关键字通常被称为模式串,因此模式匹配四个字也就好理解了。网上的很多对于KMP的讲解总是结合了很多的数学公式,很多的晦涩难懂的专业词语,让人看了很头大,至少对于蠢笨的我来说,实在是一场煎熬,因此本篇的说明尽量做到通俗易懂,从逻辑以及思考方式的角度来对模式匹配的算法进行讲解。

 

一、KMP单模式匹配算法

1、综述

在描述多模式匹配算法之前,对于单模式匹配先进行一个简单的描述。单模式匹配与多模式匹配的不同点在于单模式匹配是搜索一个关键字,多模式匹配是搜索多个关键字。

         单模式匹配解决的是在长度为m的目标串(一个长字符串L)中查找长度为n的模式串(短字符串S)的问题,如果按照最粗糙的方法暴力求解,代码应该是这样的:

         for(inti=0; i<m; i++){

                   for(intj=0; j<n; j++){

                            //依次比较L[i] 与S[j],当完全相等的情况下记录

}

}

嗯,很不错的代码,思路清晰,结构明确,就是太慢了,时间代价为O(m*n)。于是情不自禁地想要快一点,这里就请出了KMP,KMP的核心思想就是比过的字符串就不比了,为了实现这一句话,KMP在模式串的基础上&#x

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值