KMP算法(字符串匹配)(AcWing)

简介: KMP算法(字符串匹配)(AcWing)

KMP算法常用于字符串匹配,在匹配介绍KMP算法之前,先介绍如何暴力地匹配字符串

对两个字符串,用两个指针依次比较,代码:

1. for (int i = 1; i <= n; i ++ )
2. {
3. bool flag = true;
4. for (int j = 1; j <= m; j ++ )
5.     {
6. if (s[i + j - 1] != p[j])
7.         {
8.             flag=false;
9. break;
10.         }
11.     }
12. }

如果不匹配,相当于将短的那个字符串向右移动一位继续匹配,但这样依次比较的效率是非常低的

而KMP则是利用已经匹配好的字符串这个有效信息来减少重复的匹配

例如有图中,当长串和短串匹配成功了一段区间之后,在图中i和j+1的位置匹配失败了,按照常规思路我们是需要将短串向后移动一个位置继续重新开始匹配,但kmp就是利用好已经匹配好了的信息来减少匹配次数,就是令j=ne[j],从ne[j]的位置开始匹配,因为在图中我们用黑线画的部分其实是等效的,所以这一部分我们是不需要去匹配的,那么如何求这个ne[j]数组呢

这里要引入一个概念,就是前缀后缀

现在思路我们知道了,那么如何用代码来实现呢?

思路:

代码:

1.  for (int i = 2, j = 0; i <= m; i++)
2.  {
3.    while (j && str1[i] != str1[j + 1])j = ne[j];
4.    if (str1[j + 1] == str1[i])j++;
5.      ne[i] = j;
6.  }

接下来来模拟一个样例:

题目:

AC代码:

1. #include<iostream>
2. #include<cstring>
3. using namespace std;
4. const int N = 1000010, M = 10010;
5. char str[N], str1[M];
6. int ne[N], n, m;
7. 
8. int main(void)
9. {
10.   cin >>(str + 1) >>(str1 + 1);
11.   int n = strlen(str+1), m = strlen(str1+1);
12.   //获取ne数组
13.   for (int i = 2, j = 0; i <= m; i++)
14.   {
15.     while (j && str1[i] != str1[j + 1])j = ne[j];
16.     if (str1[j + 1] == str1[i])j++;
17.     ne[i] = j;
18.   }
19.   //开始匹配
20.   for (int i = 1, j = 0; i <= n; i++)
21.   {
22.     while (j && str1[j + 1] != str[i])j = ne[j];
23.     if (str[i] == str1[j + 1])j++;
24.     if (j == m)
25.     {
26.       printf("%d\n", i - m+1);
27.     }
28.   }
29.   for (int i = 1; i <= m; i++)
30.   {
31.     printf("%d ", ne[i]);
32.   }
33.   return 0;
34. }

目录
相关文章
|
2月前
|
算法
两个字符串匹配出最长公共子序列算法
本文介绍了最长公共子序列(LCS)问题的算法实现,通过动态规划方法求解两个字符串的最长公共子序列,并提供了具体的编程实现细节和示例。
97 1
两个字符串匹配出最长公共子序列算法
|
2月前
|
算法
第四章 KMP算法理论基础
第四章 KMP算法理论基础
22 0
|
2月前
|
算法
KMP算法
KMP算法
39 0
|
4月前
|
算法 C++
A : DS串应用–KMP算法
这篇文章提供了KMP算法的C++实现,包括计算模式串的next数组和在主串中查找模式串位置的函数,用于演示KMP算法的基本应用。
|
4月前
|
算法 Java
掌握算法学习之字符串经典用法
文章总结了字符串在算法领域的经典用法,特别是通过双指针法来实现字符串的反转操作,并提供了LeetCode上相关题目的Java代码实现,强调了掌握这些技巧对于提升算法思维的重要性。
|
4月前
|
算法
KMP算法
KMP算法
37 0
|
18天前
|
算法
基于WOA算法的SVDD参数寻优matlab仿真
该程序利用鲸鱼优化算法(WOA)对支持向量数据描述(SVDD)模型的参数进行优化,以提高数据分类的准确性。通过MATLAB2022A实现,展示了不同信噪比(SNR)下模型的分类误差。WOA通过模拟鲸鱼捕食行为,动态调整SVDD参数,如惩罚因子C和核函数参数γ,以寻找最优参数组合,增强模型的鲁棒性和泛化能力。
|
24天前
|
机器学习/深度学习 算法 Serverless
基于WOA-SVM的乳腺癌数据分类识别算法matlab仿真,对比BP神经网络和SVM
本项目利用鲸鱼优化算法(WOA)优化支持向量机(SVM)参数,针对乳腺癌早期诊断问题,通过MATLAB 2022a实现。核心代码包括参数初始化、目标函数计算、位置更新等步骤,并附有详细中文注释及操作视频。实验结果显示,WOA-SVM在提高分类精度和泛化能力方面表现出色,为乳腺癌的早期诊断提供了有效的技术支持。
|
4天前
|
供应链 算法 调度
排队算法的matlab仿真,带GUI界面
该程序使用MATLAB 2022A版本实现排队算法的仿真,并带有GUI界面。程序支持单队列单服务台、单队列多服务台和多队列多服务台三种排队方式。核心函数`func_mms2`通过模拟到达时间和服务时间,计算阻塞率和利用率。排队论研究系统中顾客和服务台的交互行为,广泛应用于通信网络、生产调度和服务行业等领域,旨在优化系统性能,减少等待时间,提高资源利用率。
|
11天前
|
存储 算法
基于HMM隐马尔可夫模型的金融数据预测算法matlab仿真
本项目基于HMM模型实现金融数据预测,包括模型训练与预测两部分。在MATLAB2022A上运行,通过计算状态转移和观测概率预测未来值,并绘制了预测值、真实值及预测误差的对比图。HMM模型适用于金融市场的时间序列分析,能够有效捕捉隐藏状态及其转换规律,为金融预测提供有力工具。