字符串匹配新秀之Sunday

2023-12-03 22:18
文章标签 字符串 匹配 新秀 sunday

本文主要是介绍字符串匹配新秀之Sunday,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Sunday算法的大致思想是,以pos表示本次匹配的目标串tar的起始位置,len_m表示模式串的长度,当出现不匹配的时候,看从pos开始长为len_m的一段字串的最后一个字符k是否在模式串中出现过,判断是否出现过是通过从右到左扫描模式串得到的,只要碰到k,记录下其位置i,将pos+i作为新的pos(pos+=i),继续匹配。这就扯出了next数组,不要将这个next数组跟KMP中的数组牵连起来,二者没任何关系。next数组就是记录模式串中的字母离串尾的距离,若某个字符重复出现,则只记录最右边的那个,next初始值是模式串的长度,即如果某个字符没在mode串中出现,那么pos移动时就是整体平移一个模式串的距离。next[i]表示字母i距离模式串末尾的距离,pos+next[k]表示将目标串的本次起始位置pos移动next[k]个单位,这样,新的pos位置与k的距离正好是模式串串首到k的距离。因为原来是pos-->pos+len_m,pos右移到pos+next[k]后,那么距离pos+len_m就是len_m-next[k],正好是模式串串首到k的距离。这种匹配模式思想大体上就是从中间某个字符开始匹配,这样的好处是增大了匹配成功的概率,极大减少了无用匹配次数(如rat="abcabe",mode="abe",mode与tar的前一个"ab"的匹配就是无用匹配,因为第三个字符不再匹配),有些情况下比KMP效率高,并且相对容易理解。
给个实现:

既然是字串匹配新秀,就顺便说说一个更容易理解的模式匹配算法,但论效率个个都是雄于KMP:ZZL算法

相当容易:

序需要两部
预处理
预处理主要完成查找模式串首字符在主串中的所有出现位置,并将其保存在一个数组中。

匹配
在预处理的基础上,字符串匹配算法就可以从查找到的模式串在主串中的位置开始,匹配模式串首字母之后的其余部分。此时,采用BF算法(最闻名而又最笨的字串匹配算法),并可设置一个计数器,记录匹配次数。

实现狠容易,自己看着办— —

PS:本人写博,纯属装X(a<X<c).   本文遵从CC协议,pz伯伯原创,转载注明出处。

这篇关于字符串匹配新秀之Sunday的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/451067

相关文章

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Python 常用数据类型详解之字符串、列表、字典操作方法

《Python常用数据类型详解之字符串、列表、字典操作方法》在Python中,字符串、列表和字典是最常用的数据类型,它们在数据处理、程序设计和算法实现中扮演着重要角色,接下来通过本文给大家介绍这三种... 目录一、字符串(String)(一)创建字符串(二)字符串操作1. 字符串连接2. 字符串重复3. 字

Java 字符串操作之contains 和 substring 方法最佳实践与常见问题

《Java字符串操作之contains和substring方法最佳实践与常见问题》本文给大家详细介绍Java字符串操作之contains和substring方法最佳实践与常见问题,本文结合实例... 目录一、contains 方法详解1. 方法定义与语法2. 底层实现原理3. 使用示例4. 注意事项二、su

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Java使用正则提取字符串中的内容的详细步骤

《Java使用正则提取字符串中的内容的详细步骤》:本文主要介绍Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提... 目录1. 基础流程2. 关键方法说明3. 常见场景示例场景1:提取所有数字场景2:提取邮箱地址4. 高级

SpringBoot3匹配Mybatis3的错误与解决方案

《SpringBoot3匹配Mybatis3的错误与解决方案》文章指出SpringBoot3与MyBatis3兼容性问题,因未更新MyBatis-Plus依赖至SpringBoot3专用坐标,导致类冲... 目录SpringBoot3匹配MyBATis3的错误与解决mybatis在SpringBoot3如果

Python 字符串裁切与提取全面且实用的解决方案

《Python字符串裁切与提取全面且实用的解决方案》本文梳理了Python字符串处理方法,涵盖基础切片、split/partition分割、正则匹配及结构化数据解析(如BeautifulSoup、j... 目录python 字符串裁切与提取的完整指南 基础切片方法1. 使用切片操作符[start:end]2

MyBatis的xml中字符串类型判空与非字符串类型判空处理方式(最新整理)

《MyBatis的xml中字符串类型判空与非字符串类型判空处理方式(最新整理)》本文给大家介绍MyBatis的xml中字符串类型判空与非字符串类型判空处理方式,本文给大家介绍的非常详细,对大家的学习或... 目录完整 Hutool 写法版本对比优化为什么status变成Long?为什么 price 没事?怎

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1