字符串-KMP算法

简介: 字符串-KMP算法

描述

字符串匹配的问题可以大致描述为:给定主串S(Source,长度为n),模式串P(Pattern,长度为m),要求查找出P在S中出现的位置。最常见的做法的是暴力查找,linux的string.h中使用的就是:

char * strstr(register const char *s, register constchar *wanted)
{
     register const size_t len = strlen(wanted);
     if (len ==0) return (char*)s;
     while (*s !=* wanted || strncmp(s, wanted, len))
         if (*s++=='\0')
             return (char*)NULL;
     return (char*)s;
}

该算法的复杂度是S_len * P_len。而KMP算法就是一种更好的算法,利用每次匹配的结果,尽量避免重复进行不可能位置的匹配,快速的向右移动查找结果。

KMP算法

KMP算法的主要思想是保持主串S向右移动不变,不断的回溯模式串P

主串S在位置D匹配失败,如果此时回溯模式串P的话,那么究竟移动多少其实需要看模式串的特征,即已匹配有效的部分是[ABCDAB]D括号中的部分,由于D位置不匹配,匹配串右移,[ABCDAB]移动成[AB]CDAB才能停下来。由于前面是已经匹配的部分,而移动的又是模式串,移动的模式串的过程其实是模式串前缀和模式串后缀匹配的过程,即:

  • 模式串移动位数 = 已匹配的模式串位数 - 模式串中前缀和后缀最大公共长度

前缀和后缀最大公共长度

该部分的思想较为简单,其实是根据P[0…i]求P[i+1]的长度的问题,详细算法见下图。

![KMP](/public/blog-img/algorithm/kmp.png)

本文作者 : cyningsun

本文地址https://www.cyningsun.com/04-04-2016/kmp.html

版权声明 :本博客所有文章除特别声明外,均采用 CC BY-NC-ND 3.0 CN 许可协议。转载请注明出处!

目录
相关文章
|
3月前
|
算法
【算法】滑动窗口——找到字符串中所有字母异位词
【算法】滑动窗口——找到字符串中所有字母异位词
|
1月前
|
算法
两个字符串匹配出最长公共子序列算法
本文介绍了最长公共子序列(LCS)问题的算法实现,通过动态规划方法求解两个字符串的最长公共子序列,并提供了具体的编程实现细节和示例。
87 1
两个字符串匹配出最长公共子序列算法
|
1月前
|
算法
第四章 KMP算法理论基础
第四章 KMP算法理论基础
19 0
|
1月前
|
算法
KMP算法
KMP算法
33 0
|
3月前
|
算法 C++
A : DS串应用–KMP算法
这篇文章提供了KMP算法的C++实现,包括计算模式串的next数组和在主串中查找模式串位置的函数,用于演示KMP算法的基本应用。
|
3月前
|
算法 Java
掌握算法学习之字符串经典用法
文章总结了字符串在算法领域的经典用法,特别是通过双指针法来实现字符串的反转操作,并提供了LeetCode上相关题目的Java代码实现,强调了掌握这些技巧对于提升算法思维的重要性。
|
3月前
|
算法
KMP算法
KMP算法
29 0
|
3月前
|
算法 C++
惊爆!KPM算法背后的秘密武器:一行代码揭秘字符串最小周期的终极奥义,让你秒变编程界周期大师!
【8月更文挑战第4天】字符串最小周期问题旨在找出字符串中最短重复子串的长度。KPM(实为KMP,Knuth-Morris-Pratt)算法,虽主要用于字符串匹配,但其生成的前缀函数(next数组)也可用于求解最小周期。核心思想是构建LPS数组,记录模式串中每个位置的最长相等前后缀长度。对于长度为n的字符串S,其最小周期T可通过公式ans = n - LPS[n-1]求得。通过分析周期字符串的特性,可证明该方法的有效性。提供的C++示例代码展示了如何计算给定字符串的最小周期,体现了KPM算法在解决此类问题上的高效性。
83 0
|
1月前
|
算法 安全 数据安全/隐私保护
基于game-based算法的动态频谱访问matlab仿真
本算法展示了在认知无线电网络中,通过游戏理论优化动态频谱访问,提高频谱利用率和物理层安全性。程序运行效果包括负载因子、传输功率、信噪比对用户效用和保密率的影响分析。软件版本:Matlab 2022a。完整代码包含详细中文注释和操作视频。
|
9天前
|
算法 数据安全/隐私保护 索引
OFDM系统PAPR算法的MATLAB仿真,对比SLM,PTS以及CAF,对比不同傅里叶变换长度
本项目展示了在MATLAB 2022a环境下,通过选择映射(SLM)与相位截断星座图(PTS)技术有效降低OFDM系统中PAPR的算法实现。包括无水印的算法运行效果预览、核心程序及详尽的中文注释,附带操作步骤视频,适合研究与教学使用。
下一篇
无影云桌面