【LeetCode 刷题】字符串-字符串匹配(KMP)

此博客为《代码随想录》字符串章节的学习笔记,主要内容为字符串匹配 KMP 算法相关的题目解析。

文章目录

  • [28. 找出字符串中第一个匹配项的下标](#28. 找出字符串中第一个匹配项的下标)
  • [459. 重复的子字符串](#459. 重复的子字符串)

28. 找出字符串中第一个匹配项的下标

题目链接

python 复制代码
class Solution:
    def getNext(self, s: str) -> List[int]:
        j, nxt = 0, [0] * len(s)
        for i in range(1, len(s)):
            while j > 0 and s[i] != s[j]:
                j = nxt[j - 1]
            if s[i] == s[j]:
                j += 1
            nxt[i] = j
        return nxt
        
    def strStr(self, haystack: str, needle: str) -> int:
        j, nxt = 0, self.getNext(needle)
        for i in range(len(haystack)):
            while j > 0 and haystack[i] != needle[j]:
                j = nxt[j - 1]
            if haystack[i] == needle[j]:
                j += 1
            if j == len(needle):
                return i - j + 1
        return -1
  • getNext 用于计算 next 数组,next 数组是模式串的特征规律,与文本串无关
  • 在此代码中的 next 数组的定义下,每次遇到矛盾,都需要查找上一个元素next 数组中的值,以确定回溯位置
  • getNext 函数中 j 表示的是目前最长公共前后缀的长度(也指向着公共前缀的末尾);i 指向着公共后缀的末尾
  • getNext 的 for 循环:i 从 1 开始 ,因为 i 为 0 时表示着长度为 1 的串,最长公共前后缀长度为 0,即 next[0] = 0(在数组初始化时已经完成)
  • strStr 的 for 循环:i 从 0 开始 ,完整遍历文本串 haystack

459. 重复的子字符串

题目链接

python 复制代码
class Solution:
    def getNext(self, s: str) -> List[int]:
        j, nxt = 0, [0] * len(s)
        for i in range(1, len(s)):
            while j > 0 and s[i] != s[j]:
                j = nxt[j - 1]
            if s[i] == s[j]:
                j += 1
            nxt[i] = j
        return nxt

    def repeatedSubstringPattern(self, s: str) -> bool:
        nxt = self.getNext(s)
        if nxt[-1] != 0 and len(s) % (len(s) - nxt[-1]) == 0:
            return True
        return False
  • 如果字符串 s 是由重复子串组成,那么最长相等前后缀不包含的子串 一定是 s 的最小重复子串,证明过程
  • 因此仿照 KMP 算法计算 next 数组,判断是否存在最长相等前后缀,以及最长相等前后缀不包含的子串的长度 len(s) - nxt[-1] ,是否能够被原字符串长度整除

移动匹配法(通用做法)

python 复制代码
class Solution:
    def repeatedSubstringPattern(self, s: str) -> bool:
        s_ = (s + s)[1:-1]
        return s in s_
  • 自身加自身得到 s_,之后移除第一和最后一个元素(破坏原始串),判断 s_ 中是否包含自身 s
相关推荐
C++、Java和Python的菜鸟8 分钟前
第1章 集合高级
java·jvm·python
可编程芯片开发33 分钟前
基于VSG虚拟同步发电机控制的三相并网逆变器带多组可变负载Simulink建模与仿真
算法
AI服务老曹37 分钟前
国产NPU视觉算法参数配置说明
算法·性能优化·边缘计算
彦为君1 小时前
Redis最新版本特性
java·数据库·redis·算法·bootstrap
码来的小朋友1 小时前
手把手教你用 Python + PyQt5 做一个可视化图片切图工具
开发语言·python·microsoft
weixin199701080161 小时前
[特殊字符]《京东订单API(jd.order.detail.get)对接ERP:企业认证+OAuth授权避坑指南》(附Python源码)
java·数据库·python
触底反弹1 小时前
🔥 字符串算法面试三连击:反转、回文、回文变种,搞懂这三题稳了!
前端·javascript·算法
云烟成雨TD2 小时前
LangFlow 1.x 系列【3】入门案例
人工智能·python·agent
创世宇图2 小时前
【Python工程化实战】Python 服务的结构化日志体系:structlog + JSON 输出 + 日志分级策略
python·elk·structlog·结构化日志·可观测性
aaaameliaaa2 小时前
计算斐波那契数(递归、迭代)(1,1,2,3,5.....)
c语言·开发语言·笔记·算法·排序算法