LeetCode面试刷题技巧- 字符串匹配习题集

Posted 文宇肃然

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode面试刷题技巧- 字符串匹配习题集相关的知识,希望对你有一定的参考价值。

字符串匹配之Horspool算法

Boyer-Moore-Horspool是一种 字符串匹配 算法,它将从 模式的末尾 到开始比较字符。其首先检查与最后一个模式字符对齐的文本字符,当字符 不匹配 时,搜索跳到模式中的 下一个匹配 位置;如果都不匹配,将模式向前移动直到匹配为止。换句话说,Boyer-Moore-Horspool算法是一种在字符串中查找子字符串的算法。

Horspool算法由Nigel Horspool在1980年发表,Nigel Horspool是维多利亚大学的计算机科学教授。该算法时基于Boyer Moore字符串搜索算法的研究,与Knuth Morris Pratt算法相关,旨在创建一种更高效的算法,在最坏情况下达到原始复杂度。

horspool算法将主串中 匹配窗口 的最后一个字符跟模式串中的最后一个字符比较。如果相等,继续从后向前对主串和模式串进行比较,直到完全相等或者在某个字符处不匹配为止(如下图中的α与σ失配) 。如果不匹配,则根据主串匹配窗口中的最后一个字符β在模式串中的下一个出现位置将窗口向右移动。

搜索窗口的理解:

  • 窗口大小与模式串大小相同,窗口内容为文本内容的一部分。

  • 对于窗口而言,每次从后向前匹配&#

以上是关于LeetCode面试刷题技巧- 字符串匹配习题集的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode面试刷题技巧- B树习题集

LeetCode面试刷题技巧-二分查找算法代码思路解析

LeetCode面试刷题技巧-二分查找算法(下):通过 LeetCode 学习二分查找算法-销售价值减少的颜色球

leetcode刷题69.分割平衡字符串——Java版

#leetcode刷题之路44-通配符匹配

leetcode刷题——一些算法技巧总结1.0