子串问题(BF算法、KMP算法)

一、问题描述

假设字符串A: "abcababcabc"

       字符串B:"abcabc"

因为字符串A中有一部分和B相同,则称字符串B为字符串A的子串

二、BF算法

用i 和 j 分别表示字符串AB的下标,初始值都为0。

下标 0 1 2 3 4 5 6 7 8 9 10
字符串A a b c a b a b c a b c
  i                    
字符串B a b c a b c          
  j                    

1、首先字符串A从头开始,判断往后strlen(B)个字符串是否和字符串B相等;

下标 0 1 2 3 4 5 6 7 8 9 10
字符串A a b c a b a b c a b c
            i          
字符串B a b c a b c          
            j          

2、当走到下标为5的时候,字符串A B失配,则说明字符串A从下标为0开始的子串与B不相同,既然从下标为0开始没有,那就i回退到1(即回退了i - j + 1),j回退到0,再次进行匹配

下标 0 1 2 3 4 5 6 7 8 9 10
字符串A a b c a b a b c a b c
    i                  
字符串B a b c a b c          
  j                    

3、当i为1,j为0是还是失配,i接着回退i - j + 1 &

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值