第四章 字符串part02(KMP待完成)

本文介绍了如何实现strStr()函数,以及KMP算法在459题中的应用,同时提及了字符串总结和双指针技巧的回顾,建议初学者先了解基本思路,后续再深入学习算法细节。
摘要由CSDN通过智能技术生成

今日任务 

  • 28. 实现 strStr()
  • 459.重复的子字符串
  • 字符串总结 
  • 双指针回顾 

 详细布置 

28. 实现 strStr()  (本题可以跳过)

因为KMP算法很难,大家别奢求 一次就把kmp全理解了,大家刚学KMP一定会有各种各样的疑问,先留着,别期望立刻啃明白,第一遍了解大概思路,二刷的时候,再看KMP会 好懂很多。

或者说大家可以放弃一刷可以不看KMP,今天来回顾一下之前的算法题目就可以。

因为大家 算法能力还没到,细扣 很难的算法,会把自己绕进去,就算别人给解释,只会激发出更多的问题和疑惑。所以大家先了解大体过程,知道这么回事, 等自己有 算法基础和思维了,在看多看几遍视频,慢慢就理解了。

题目链接/文章讲解/视频讲解:

自己写了一个:

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

 459.重复的子字符串  (本题可以跳过)

本题算是KMP算法的一个应用,不过 对KMP了解不够熟练的话,理解本题就难很多。 

我的建议是 KMP和本题,一刷的时候 ,可以适当放过,了解怎么回事就行,二刷的时候再来硬啃

题目链接/文章讲解/视频讲解:代码随想录

字符串总结 

比较简单,大家读一遍就行 

题目链接/文章讲解:代码随想录

char a[5] = "asd";
for (int i = 0; a[i] != '\0'; i++) {
}

 双指针回顾 

此时我们已经做过10到双指针的题目了,来一起回顾一下,大家自己也总结一下双指针的心得 

文章讲解:代码随想录

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值