博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[算法之美] KMP算法的直观理解
阅读量:5049 次
发布时间:2019-06-12

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

  KMP算法是解决字符串匹配问题的,简单说来,其实就是问“P串(Pattern串)是不是T串(Text串)的子串,如果是的话就回答子串在P中的起始位置(即Index函数的返回值)”。

  穷举的算法是摆好T串并固定,然后手拿着P串一个一个比对。(我们假设i是指向T串的,j是指向P串的)

  现在我们拿着P串,看它的第1个字符和T串的第1个字符是不是相同的,是的话就看它的第2个字符和T串的第2个字符是不是相同的……不是的话就把P串右移一格,然后{

    看P串的第1个和T串的第2个是不是相同的,是的话就看它的第2个和T串的第3个是不是相同的……不是相同的话就把P串右移一格,然后

    看P串的第一个和T串的第二个是不是相同的,是的话就看它的第二个和T串的第三个是不是相同的……不是相同的话就把P串右移一格,循环往复。

 

    直到P串的最后一个字符也和T串相同时结束,此时(i-P串长度)就是子串在P中的起始位置。

 

  而这种方法效率是很低的,主要是每次一有不匹配的情况就只能右移1格然后从P串的第一个开始重新比较。

  KMP就是为了解决这样低效率的问题的。我们看这样一个例子:

        T串是:ababaab

        P串是:ababc

  

转载于:https://www.cnblogs.com/G-M-WuJieMatrix/p/7112671.html

你可能感兴趣的文章
Android入门之文件系统操作(二)文件操作相关指令
查看>>
Android实现 ScrollView + ListView无滚动条滚动
查看>>
Swift 中的指针使用
查看>>
Swift - 使用闭包筛选过滤数据元素
查看>>
alue of type java.lang.String cannot be converted to JSONObject
查看>>
搜索引擎选择: Elasticsearch与Solr
查看>>
JAVA设计模式之简单工厂模式与工厂方法模式
查看>>
③面向对象程序设计——封装
查看>>
【19】AngularJS 应用
查看>>
Spring
查看>>
Linux 系统的/var目录
查看>>
Redis学习---Redis操作之其他操作
查看>>
WebService中的DataSet序列化使用
查看>>
BZOJ 1200 木梳
查看>>
【Linux】【C语言】菜鸟学习日志(一) 一步一步学习在Linxu下测试程序的运行时间...
查看>>
hostname
查看>>
SpringBoot使用其他的Servlet容器
查看>>
关于cookie存取中文乱码问题
查看>>
k8s架构
查看>>
select 向上弹起
查看>>