当前位置: 首页 > news >正文

KMP 详解

KMP数组存的是什么

对于一个字符串 b,下标从1开始。

则kmp[i]表示 以i结尾的连续子串 = s的前缀的最大值(等价于前缀最大结尾处)

如何求KMP

假设 i 以前的KMP都被求出来了。

j 表示上一个字符可以成功匹配的长度(等价于下标)

如果b[j+1] != b[i]下一个位置匹配不上(即不能成为前缀)

则,让j = kmp[j] 即成为以j结尾的 连续子串 的 最长前缀 尾部的下标

退出循环后,若还能匹配上则j++(本质是,加上i的贡献。因为j = 0时可能匹配不上)

然后让kmp[i] = j即可。

运用kmp

和求kmp差不多,如果匹配不上,求让a[i]和以j结尾的连续子串的最长前缀匹配。(放宽要求)

算法正确性证明

用哲学的话来说就是,每一次失败都会让我变得更强大。

当匹配不上时,匹配串b至少会前移1位,由指针的思想。O(n)可证。

#include<bits/stdc++.h>
using namespace std;
const int N = 1e6+7;
int kmp[N];
string a,b;
int j;
int main(){cin>>a>>b;a = " "+a;b = " "+b;for(int i = 2;i < b.size();i++){while(j&&b[j+1] != b[i]){j = kmp[j];}if(b[j+1] == b[i])j++;kmp[i] = j;}j = 0;for(int i = 1;i < a.size();i++){while(j&&a[i] != b[j+1]){j = kmp[j];}if(b[j+1] == a[i])j++;if(j == b.size()-1){cout<<i-(b.size()-1)+1<<endl;j=kmp[j];}}for (int i=1;i < b.size();i++)cout<<kmp[i]<<" ";return 0;
}

 

http://www.lryc.cn/news/431346.html

相关文章:

  • go语言并发编程-超详细mutex解析
  • VirtualBox Debian 自动安装脚本
  • 最好的开放式耳机?五款红榜开放式耳机推荐!
  • 线性代数之线性方程组
  • 速盾:怎么查看是否使用cdn服务?
  • 828华为云征文|采用Flexus云服务器X实例部署RTSP直播服务器
  • Spring Cloud Gateway(二)
  • docker 简易入门
  • 【看雪-注册安全分析报告】
  • 记录一个前端学习小组的收集的模版
  • Rk3588 Android12 AIDL 开发
  • 两个长整数字符串求和(不允许使用ES6+)
  • 11 Java 方法引用、异常处理、Java接口之函数式编程(接口知识补充Function<T,R>、BiFunction<T, U, R>和自定义泛型接口)
  • 深入探索 Go 语言的编译器与垃圾回收机制
  • 2024国赛数学建模-模拟火算法(MATLAB 实现)
  • YOLOv8 只检测人 只画框不要标签
  • 如何将网络安全防范游戏化
  • Qt QGraphicsView实现图片放缩、鼠标拖动移动、鼠标点位置放大缩小_图片查看
  • Percona Toolkit 神器全攻略(复制类)
  • SQLite3 数据类型深入全面讲解
  • Python高效实现Trie(前缀树)及其插入和查找操作
  • 傅里叶变换家族
  • 深度学习——强化学习算法介绍
  • 轴承知识大全,详细介绍(附3D图纸免费下载)
  • 【PyTorch】基础环境如何打开
  • QT教程:QTime和QTimer的使用场景
  • MySQL 迁移中 explicit_defaults_for_timestamp 参数影响
  • 树状数组记录
  • 客户端时间和服务器时间的区别
  • 已入职华为!!关于我成功拿下华为大模型算法岗经验总结