数据结构 笔记:KMP子串查找算法

KMP算法通过部分匹配表优化了子串查找的效率,避免了不必要的字符回溯。部分匹配值是前缀和后缀最长共有元素的长度,可以递推生成。在匹配失败时,移动位数等于已匹配字符数减去对应的部分匹配值。这种算法提高了字符串匹配的性能。
摘要由CSDN通过智能技术生成

发现

-匹配失败时的右移位数与子串本身相关,与目标串无关

-移动位数=已匹配的字符数-对应的部分匹配值

-任意子串都穿在一个唯一的部位匹配表

前缀

-除了最后一个字符以外,一个字符串的全部头部组合

后缀

-出了第一个字符以外,一个字符串的全部尾部组合

部分匹配值

-前缀和后缀最长共有元素的长度

  字符 前缀 后缀 交集 匹配
1 A 0
2 AB A B 0
3 ABC A,AB BC,C
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值