理解KMP

简介: 理解KMP

KMP

问题

字符串匹配问题,问字符串 str1中是否存在连续的子串与字符串str2相等,存在返回子串的起始位置,否则返回-1


思路

传统做法是依次遍历str1中的每个字符作为起始位置,看是否能凑出字符串str2.

KMP算法就是对传统做法的一种加速,对于有些节点是可以跳过的


数据

数组next : 用于存储下标i前面长度为i-1的字符串 前缀 和 后缀相等的最长长度


实现

int f1(string str1,string str2)
{
    if(str1.size() < str2.size()) return 0;
    vector<int> arr = GetNextArr(str2);
    int i1 = 0 , i2 = 0;
    while(i1 < str1.size())
    {
        if(str1[i1] == str2[i2])
        {
            i1++;
            i2++;
        }
        else if(next[i2] == -1)
        {
            i1++;
        }
        else
        {
            i2 = next[i2];
        }
    }
    return i2 == str2.size() ? i1 - i2 : -1;
}
vector<int> GetNextArr(string str)
{
    if(str2.size() == 1)
    {
        return vector<int>(1,-1);
    }
    vector<int> next(str.size());
    next[0] = -1;
    next[1] = 0;
    int cn = 0;
    int i = 2;
    while(i < str.size())
    {
        if(next[cn] == str[i - 1])
        {
            next[i++] = ++cn;
        }
        else if(cn > 0)
        {
            cn = next[cn];
        }
        else
        {
            next[i++] = 0;
        }
    }
    return next;
}

思考

如何做到加速

2c169156de014beda3b113d126ef1cf1.png 当i1位置字符和i2位置字符不相等时,i2来到前 i2 - 1 的 前缀和后缀相等的最长长度的下一个位置也就是next[i2].


因为i1前的字符和i2前的字符相等,可得到如图的切割,比较i1和k的字符,相当于str1的比较起始位置来到切割位置


为何可以跳过切割位置前面的字符


cf37419804a14a0d9aa55fb3f599fb59.png

假设S位置起始可以凑出字符串str2,那Si1-1的长度A应与str2中的长度B中的字符相等。

由于i1前的字符和i2前的字符相等,则相等长度CA中的字符应该相等,=》A=B=C

B=C,得到新的前缀和后缀相等的最长长度,违背了我们之前算出的结果,所以S起始不成立

目录
相关文章
|
开发工具
Python----使用schedule模块可以非常简单地设置定时任务
Python----使用schedule模块可以非常简单地设置定时任务
1634 0
|
11月前
|
人工智能 物联网 UED
自修复材料:未来材料的自我修复能力
【10月更文挑战第14天】自修复材料作为未来材料的重要发展方向之一,以其独特的自我修复能力,正逐步改变着我们的生活和工作方式。通过深入了解其原理、分类、创新性研究及应用前景,我们可以更加清晰地看到自修复材料在推动社会进步和科技创新中的重要作用。让我们共同期待自修复材料在未来带来的更多惊喜和变革!
|
机器学习/深度学习 人工智能 算法
【服装识别系统】图像识别+Python+人工智能+深度学习+算法模型+TensorFlow
服装识别系统,本系统作为图像识别方面的一个典型应用,使用Python作为主要编程语言,并通过TensorFlow搭建ResNet50卷积神经算法网络模型,通过对18种不同的服装('黑色连衣裙', '黑色衬衫', '黑色鞋子', '黑色短裤', '蓝色连衣裙', '蓝色衬衫', '蓝色鞋子', '蓝色短裤', '棕色鞋子', '棕色短裤', '绿色衬衫', '绿色鞋子', '绿色短裤', '红色连衣裙', '红色鞋子', '白色连衣裙', '白色鞋子', '白色短裤')数据集进行训练,最后得到一个识别精度较高的H5格式模型文件,然后基于Django搭建Web网页端可视化操作界面,实现用户在界面中
534 1
【服装识别系统】图像识别+Python+人工智能+深度学习+算法模型+TensorFlow
|
存储 缓存 算法
滚雪球学Java(62):HashSet的底层实现原理解析
【6月更文挑战第16天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
147 3
滚雪球学Java(62):HashSet的底层实现原理解析
|
小程序 前端开发
网络祭祀人物微信小程序模板源码
网络祭祀人物微信小程序模板源码
162 5
|
弹性计算 JavaScript Java
在 Intellij IDEA 中部署 Spring Boot / Spring Cloud 应用到阿里云
Spring Cloud 和 Spring Boot 可以说是当前最流行的微服务开发框架了,在本文中,将向读者介绍如何在 在 Intellij IDEA 中部署 Spring Boot / Spring Cloud 应用到阿里云。
14070 103
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的企业OA管理系统的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue+uniapp的企业OA管理系统的详细设计和实现(源码+lw+部署文档+讲解等)
186 1
|
Windows
修改SubVI的LabVIEW默认搜索路径
修改SubVI的LabVIEW默认搜索路径
252 0
|
网络协议 安全
ensp中nat server 公网访问内网服务器
ensp中nat server 公网访问内网服务器
432 1
|
Kubernetes 网络协议 Docker
Docker 容器的DNS
Docker 容器的DNS
341 1