博客
关于我
(转)字符串匹配的Boyer-Moore算法
阅读量:125 次
发布时间:2019-02-26

本文共 492 字,大约阅读时间需要 1 分钟。

Boyer-Moore算法是一种高效的字符串搜索算法,它通过位移比较来优化搜索过程。以下是对算法中坏位置(Bad Position)和上一次出现位置(Last Occurrence Position)计算方法的详细说明。

在“3.”的示例中,假设我们需要在长字符串中查找单词“example”。当位移比较过程开始时,我们需要确定坏位置和上一次出现位置。

首先,坏位置是指在当前搜索词匹配位置不一致的位置。在这个例子中,当搜索词“example”与长字符串中的某一部分进行比较时,我们发现“e”与长字符串中的“p”不匹配。此时,坏位置被确定为“example”中的“e”位置(即第6个字符),而长字符串中的“p”位于“example”中的第4个字符位置。

接下来,我们需要确定上一次出现位置。上一次出现位置是指在搜索词中,上一次出现与当前坏位置匹配字符的位置。在这个例子中,上一次出现位置是“example”中的“p”位置(即第4个字符)。

这种方法通过位移比较的方式,能够快速定位到不匹配的位置,从而优化搜索过程。这种机制使得Boyer-Moore算法在处理大型字符串时显得尤为高效。

转载地址:http://rnnf.baihongyu.com/

你可能感兴趣的文章
PHPExcel一些基本设置总结
查看>>
phpexcel中文手册
查看>>
PHPExcel导入导出 若在thinkPHP3.2中使用(无论实例还是静态调用(如new classname或classname::function)都必须加反斜杠,因3.2就命名空间,如/c...
查看>>
phpize及其用法
查看>>
phpMailer发送邮件
查看>>
PHPMailer发送邮件
查看>>
phpmailer发送邮件,可以带附件
查看>>
phpmailer的用法
查看>>
phpmyadmin 安装
查看>>
phpmyadmin导出数据库出现Fatal error: Cannot 'break' 2 levels in D:\phpstudy\WWW\phpMyAdmin
查看>>
phpmyadmin数据库建表及插入
查看>>
phpnow配置
查看>>
phprpc简单使用
查看>>
phpspider中当爬虫获取数据时如何去掉广告
查看>>
phpstorm 2016.3.3 激活
查看>>
phpstorm中Xdebug的使用
查看>>
phpstorm中使用svn版本控制器
查看>>
phpstorm配置php脚本执行
查看>>
PhpStorm配置远程xdebug
查看>>
phpstudy+iis搭建php项目
查看>>