字符串-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 许可协议。转载请注明出处!

目录
相关文章
|
5月前
|
算法
【算法】滑动窗口——找到字符串中所有字母异位词
【算法】滑动窗口——找到字符串中所有字母异位词
|
3月前
|
算法
两个字符串匹配出最长公共子序列算法
本文介绍了最长公共子序列(LCS)问题的算法实现,通过动态规划方法求解两个字符串的最长公共子序列,并提供了具体的编程实现细节和示例。
111 1
两个字符串匹配出最长公共子序列算法
|
3月前
|
算法
第四章 KMP算法理论基础
第四章 KMP算法理论基础
28 0
|
3月前
|
算法
KMP算法
KMP算法
48 0
|
5月前
|
算法 C++
A : DS串应用–KMP算法
这篇文章提供了KMP算法的C++实现,包括计算模式串的next数组和在主串中查找模式串位置的函数,用于演示KMP算法的基本应用。
|
5月前
|
算法 Java
掌握算法学习之字符串经典用法
文章总结了字符串在算法领域的经典用法,特别是通过双指针法来实现字符串的反转操作,并提供了LeetCode上相关题目的Java代码实现,强调了掌握这些技巧对于提升算法思维的重要性。
|
5月前
|
算法
KMP算法
KMP算法
40 0
|
5月前
|
算法 C++
惊爆!KPM算法背后的秘密武器:一行代码揭秘字符串最小周期的终极奥义,让你秒变编程界周期大师!
【8月更文挑战第4天】字符串最小周期问题旨在找出字符串中最短重复子串的长度。KPM(实为KMP,Knuth-Morris-Pratt)算法,虽主要用于字符串匹配,但其生成的前缀函数(next数组)也可用于求解最小周期。核心思想是构建LPS数组,记录模式串中每个位置的最长相等前后缀长度。对于长度为n的字符串S,其最小周期T可通过公式ans = n - LPS[n-1]求得。通过分析周期字符串的特性,可证明该方法的有效性。提供的C++示例代码展示了如何计算给定字符串的最小周期,体现了KPM算法在解决此类问题上的高效性。
100 0
|
12天前
|
机器学习/深度学习 算法
基于改进遗传优化的BP神经网络金融序列预测算法matlab仿真
本项目基于改进遗传优化的BP神经网络进行金融序列预测,使用MATLAB2022A实现。通过对比BP神经网络、遗传优化BP神经网络及改进遗传优化BP神经网络,展示了三者的误差和预测曲线差异。核心程序结合遗传算法(GA)与BP神经网络,利用GA优化BP网络的初始权重和阈值,提高预测精度。GA通过选择、交叉、变异操作迭代优化,防止局部收敛,增强模型对金融市场复杂性和不确定性的适应能力。
145 80
|
1天前
|
机器学习/深度学习 数据采集 算法
基于GA遗传优化的CNN-GRU-SAM网络时间序列回归预测算法matlab仿真
本项目基于MATLAB2022a实现时间序列预测,采用CNN-GRU-SAM网络结构。卷积层提取局部特征,GRU层处理长期依赖,自注意力机制捕捉全局特征。完整代码含中文注释和操作视频,运行效果无水印展示。算法通过数据归一化、种群初始化、适应度计算、个体更新等步骤优化网络参数,最终输出预测结果。适用于金融市场、气象预报等领域。
基于GA遗传优化的CNN-GRU-SAM网络时间序列回归预测算法matlab仿真

热门文章

最新文章