iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >c++KMP字符串匹配算法
  • 351
分享到

c++KMP字符串匹配算法

2024-04-02 19:04:59 351人浏览 安东尼
摘要

目录KMP算法简介前缀表如何构造前缀表next数组如何用next数组进行模板匹配总结KMP算法简介        

KMP算法简介

        KMP算法(Knuth-Morris-Pratt 算法)是一个著名的字符串匹配算法,它主要的思想是当出现字符串不匹配时,可以知道一部分之前已经匹配的文本内容,可以利用这些信息避免从头再去做匹配。

        本章以力扣 28. 实现 strStr()为例子进行讲解。

        力扣28.实现strStr()函数:给你两个字符串 haystack 和 needle ,请你在 haystack 字符串中找出 needle 字符串出现的第一个位置(下标从 0 开始)。如果不存在,则返回  -1 。

        说明:当 needle 是空字符串时,我们应当返回什么值呢?这是一个在面试中很好的问题。对于本题而言,当 needle 是空字符串时我们应当返回 0 。

        示例 1: 输入:haystack = "hello", needle = "ll"        输出:2

  此题若用暴力解法代码如下:

class Solution {
public:
    int strStr(string haystack, string needle) {
        int n=haystack.size(),m=needle.size();
        if(m==0) return 0;
        for(int i=0;i<n;i++){
            if(haystack[i]==needle[0]){
                for(int j=0;j<m;j++){
                    if(haystack[i+j]!=needle[j])
                        break;
                    if(j==m-1) return i;
                }
            }
        }
        return -1;
    }
};

         可见暴力匹配过程中实现的是一个双层循环,那么算法的时间复杂度较高,为О(n*m),然而KMP的算法时间复杂度仅为О(n+m),其算法性能明显提高,具体时间复杂度计算方法后面介绍。

前缀表

        KMP算法中一个重要的概念就是前缀表(prefix table),并用一维数组 next 记录前缀信息实际上next数组就是一个前缀表。

        了解前缀表我们首先需要了解前缀和后缀的区别,此处的前缀是指不包含最后一个字符的所有以第一个字符开头的连续子串,后缀是指不包含第一个字符的所有以最后一个字符结尾的连续子串。比如字符串“abac”的前缀有“a”, "ab”, "aba”,字符串“abac”的后缀有“c”,"ac”,"bac”。

        前缀表第 i 个位置存的值 next[i] 代表[0,i]这个字符串最长的相同前后缀的长度,比如字符串“abbc”的 next[3]为 0 ,next[2]为 1 ("aba”的前缀有“a”, "ab”,后缀有“a”,"ba”)。

        前缀表的作用是用来记录了模板串与主串(文本串)不匹配的时候,模板串应该从哪里开始重新匹配。

        KMP算法的核心思想就是先求出匹配模板的next数组,再运用next数组进行字符串匹配。  

如何构造前缀表next数组

void get_next(int *next,string t){ //t为模板字符串
        //定义两个指针prefix和suffix,prefix指向前缀起始位置,suffix指向后缀起始位置
        int prefix=0;
        next[prefix]=0;
        for(int suffix=1;suffix<t.size();suffix++){
            while(prefix>0 && t[suffix]!=t[prefix]){//前后缀不相同,前缀指针向前回退
                prefix=next[prefix-1];
            }
            if(t[suffix]==t[prefix]){//前后缀相同,前缀指针前进一位
                prefix++; 
            }
            next[suffix]=prefix;//更新next数组,prefix走到哪说明就有多少的相同的前后缀
        }
    }

如何用next数组进行模板匹配

int strStr(string haystack, string needle) {
        if(needle.size()==0) return 0;
        int next[needle.size()];
        get_next(next,needle);
        int j=0;
        //定义两个下标j指向模版串起始位置,i指向文本串起始位置
        for(int i=0;i<haystack.size();i++){
            while(j>0 && haystack[i]!=needle[j]){ //模版串j位置和文本串i位置不相同,j利用next数组回退到上一个相同的位置继续匹配
                j=next[j-1];
            }
            if(haystack[i]==needle[j]){  //模版串j位置和文本串i位置相同
                j++;
            }
            if(j==needle.size()){  //找到匹配的字符串
                return (i-needle.size()+1); //返回匹配的字符串起始位置
            }
        }
        return -1;
    }

由此可见构造next数组的时间复杂度是О(m),利用next数组进行匹配的时间复杂度是О(n),总的时间复杂度是О(n+m)

总结

到此这篇关于c++ KMP字符串匹配算法的文章就介绍到这了,更多相关c++ KMP字符串匹内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: c++KMP字符串匹配算法

本文链接: https://www.lsjlt.com/news/162122.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • c++KMP字符串匹配算法
    目录KMP算法简介前缀表如何构造前缀表next数组如何用next数组进行模板匹配总结KMP算法简介        ...
    99+
    2024-04-02
  • 如何使用java暴力匹配及KMP算法解决字符串匹配问题
    这篇文章主要介绍如何使用java暴力匹配及KMP算法解决字符串匹配问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!要解决的问题?一、暴力匹配算法一个图例介绍KMP算法String str1 =&...
    99+
    2023-06-21
  • java暴力匹配及KMP算法解决字符串匹配问题示例详解
    目录要解决的问题?一、暴力匹配算法一个图例介绍KMP算法二、KMP算法算法介绍一个图例介绍KMP算法  代码实现要解决的问题? 一、暴力匹配算法 一个图例介绍KMP算法 St...
    99+
    2024-04-02
  • C语言字符串的模式匹配之BF与KMP
    目录BF算法(Brute-Force算法)KMP算法(快速的)KMP—yxc模板总结确定一个子串(模式串)在主串中第一次出现的位置。 BF算法(Brute-Force算法) BF算法...
    99+
    2024-04-02
  • Java C++题解leetcode字符串轮转KMP算法详解
    目录题目要求思路一:双指针(模拟)JavaC++思路二:子串手写KMPJavadpC++dp调APIJavaC++总结题目要求 思路一:双指针(模拟) Java class Sol...
    99+
    2024-04-02
  • C#中怎么匹配字符串
    本篇文章为大家展示了C#中怎么匹配字符串,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。C#匹配字符串大多数重要的正则表达式语言运算符都是非转义的单个字符。转义符 \(单个反斜杠)通知正则表达式分析器...
    99+
    2023-06-18
  • java字符串模糊匹配算法怎么应用
    字符串模糊匹配算法可以应用于各种场景,例如:1. 文本搜索引擎:在搜索引擎中,用户输入的查询字符串通常是模糊的,可以使用字符串模糊匹...
    99+
    2023-09-14
    java
  • 如何理解字符串匹配的Boyer-Moore算法
    这篇文章给大家介绍如何理解字符串匹配的Boyer-Moore算法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。之前我介绍了KMP算法。但是,它并不是效率***的算法,实际采用并不多。各种文本编辑器的"查找&q...
    99+
    2023-06-17
  • java 中模式匹配算法-KMP算法实例详解
    java 中模式匹配算法-KMP算法实例详解朴素模式匹配算法的最大问题就是太低效了。于是三位前辈发表了一种KMP算法,其中三个字母分别是这三个人名的首字母大写。简单的说,KMP算法的对于主串的当前位置不回溯。也就是说,如果主串某次比较时,当...
    99+
    2023-05-31
    java kmp ava
  • CC++算法题解LeetCode1408数组中的字符串匹配
    目录题目描述整理题意解题思路分析优化具体实现复杂度分析代码实现暴力暴力 + 优化KMP总结题目描述 题目链接:1408. 数组中的字符串匹配 给你一个字符串数组 words ,数组中...
    99+
    2022-11-13
    C C++算法数组字符串匹配 C C++ 数组字符串匹配
  • shell字符串匹配的实现方法
    这篇文章主要介绍了shell字符串匹配的实现方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、简介      Bash ...
    99+
    2023-06-09
  • mysql字符串匹配的方法是什么
    MySQL提供了多种方法来进行字符串匹配,其中常用的有以下几种:1. LIKE操作符:LIKE操作符是最常用的字符串匹配方法,它可以...
    99+
    2023-10-09
    mysql
  • PHP如何计算两个字符串的匹配度
    这篇文章主要讲解了“PHP如何计算两个字符串的匹配度”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP如何计算两个字符串的匹配度”吧!计算两个字符串匹配度(相似度),也就是计算两个字符串的...
    99+
    2023-06-20
  • shell字符串匹配的方法有哪些
    使用通配符:通配符是一种简单而有效的方法来匹配字符串。在Shell中,可以使用星号(*)和问号()来代表零个或多个字符以及一个字...
    99+
    2024-04-02
  • 多模字符串匹配算法原理及Java实现代码
    多模字符串匹配算法在这里指的是在一个字符串中寻找多个模式字符字串的问题。一般来说,给出一个长字符串和很多短模式字符串,如何最快最省的求出哪些模式字符串出现在长字符串中是我们所要思考的。该算法广泛应用于关键字过滤、入侵检测、病毒检测、分词等等...
    99+
    2023-05-30
    java 多模匹配算法 多模
  • perl怎么匹配多个字符串
    在Perl中,可以使用正则表达式来匹配多个字符串。有多种方法可以实现这一点。 使用竖线(|)来表示或逻辑,例如:/string1...
    99+
    2023-10-21
    perl
  • Bash编程中如何实现高效的字符串匹配算法?
    在Bash编程中,字符串匹配是一个非常常见的需求。无论是对文件名的匹配,还是对文本内容的搜索,字符串匹配都是必不可少的。然而,在实际编程中,我们经常会遇到一些字符串匹配效率较低的问题,这给程序的性能带来了很大的影响。本文将介绍Bash编程...
    99+
    2023-08-07
    编程算法 自然语言处理 bash
  • python怎么匹配某一字符串
    在Python中,可以使用正则表达式来匹配某一字符串。可以使用`re`模块来进行正则表达式操作。下面是一个简单的示例,展示如何使用正...
    99+
    2023-08-30
    python
  • Python中如何使用通配符匹配字符串
    今天小编给大家分享一下Python中如何使用通配符匹配字符串的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。使用通配符匹配字符...
    99+
    2023-07-05
  • python怎么匹配字符串中的数字
    要匹配字符串中的数字,可以使用正则表达式来实现。下面是一个简单的示例,演示如何使用正则表达式来匹配字符串中的数字: import r...
    99+
    2024-04-08
    python
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作