首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Knuth Morris Pratt vs Boyer Moore :二进制字母表与大量字母的字母表

Knuth Morris Pratt vs Boyer Moore :二进制字母表与大量字母的字母表
EN

Stack Overflow用户
提问于 2014-07-17 22:47:46
回答 1查看 1.6K关注 0票数 2

我熟悉这两种算法: Knuth Morris Pratt和Boyer moore。

给定一个字符串P,该字符串由具有大量字母的字母表组成。使用哪种算法更好?

给定一个具有二进制字母表(0或1)的字符串P。使用哪种算法更好?

EN

回答 1

Stack Overflow用户

发布于 2014-07-18 01:13:13

与KMP相比,Boyer-Moore的主要优势是Boyer-Moore可以具有次线性运行时。但是,当您要查找的模式中没有太多不匹配的字符时,就会发生这种情况(因为这允许算法在文本中跳得更远)。在较大的字母表中,模式之外的字符更有可能不匹配,因此Boyer-Moore可能是最好的选择。但是,请记住,在最坏的情况下,BM运行在~MN中,其中M是模式的大小,N是文本的大小,而KMP保证是线性的。

对于二进制字母表,我会使用KMP。BM中的不匹配字符几乎总是在模式中,因此您可能会线性地处理整个文本,在这种情况下,两种算法之间几乎没有区别。然而,对于二进制字母表中的BM来说,遇到最坏的情况要容易得多,所以KMP更安全。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24806753

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档