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. }

目录
相关文章
|
存储 机器学习/深度学习 算法
KMP、Trie树 、AC自动机‌ ,三大算法实现 优雅 过滤 netty 敏感词
KMP、Trie树 、AC自动机‌ ,三大算法实现 优雅 过滤 netty 敏感词
KMP、Trie树 、AC自动机‌ ,三大算法实现 优雅 过滤 netty  敏感词
|
机器学习/深度学习 监控 算法
局域网行为监控软件 C# 多线程数据包捕获算法:基于 KMP 模式匹配的内容分析优化方案探索
本文探讨了一种结合KMP算法的多线程数据包捕获与分析方案,用于局域网行为监控。通过C#实现,该系统可高效检测敏感内容、管理URL访问、分析协议及审计日志。实验表明,相较于传统算法,KMP在处理大规模网络流量时效率显著提升。未来可在算法优化、多模式匹配及机器学习等领域进一步研究。
301 0
|
算法
两个字符串匹配出最长公共子序列算法
本文介绍了最长公共子序列(LCS)问题的算法实现,通过动态规划方法求解两个字符串的最长公共子序列,并提供了具体的编程实现细节和示例。
485 1
两个字符串匹配出最长公共子序列算法
|
算法 C++
A : DS串应用–KMP算法
这篇文章提供了KMP算法的C++实现,包括计算模式串的next数组和在主串中查找模式串位置的函数,用于演示KMP算法的基本应用。
|
算法
第四章 KMP算法理论基础
第四章 KMP算法理论基础
390 0
|
算法
KMP算法
KMP算法
276 0
|
8月前
|
机器学习/深度学习 算法 机器人
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
730 0
|
8月前
|
数据采集 分布式计算 并行计算
mRMR算法实现特征选择-MATLAB
mRMR算法实现特征选择-MATLAB
451 2
|
9月前
|
传感器 机器学习/深度学习 编解码
MATLAB|主动噪声和振动控制算法——对较大的次级路径变化具有鲁棒性
MATLAB|主动噪声和振动控制算法——对较大的次级路径变化具有鲁棒性
374 3
|
8月前
|
机器学习/深度学习 算法 机器人
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
351 8

热门文章

最新文章