2022年6月16日leetcode每日一题打卡——28.实现strStr()

一、题目描述与要求

28.实现strStr()

题目描述:

实现 strStr() 函数。

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

说明:

当 needle 是空字符串时,我们应当返回什么值呢?这是一个在面试中很好的问题。

对于本题而言,当 needle 是空字符串时我们应当返回 0 。这与 C 语言的 strstr() 以及 Java 的 indexOf() 定义相符。

示例:

输入:haystack = "hello", needle = "ll"
输出:2
输入:haystack = "aaaaa", needle = "bba"
输出:-1

提示:

  • 1 <= haystack.length, needle.length <= 104
  • haystack 和 needle 仅由小写英文字符组成

二、解题思路

总的思路:

核心思路就是将needle数组中的每一个字符依次与haystack数组中的每一个字符相比较,如果相等则继续比较needle中的第二个字符,直至相等用此时haystack的下标i减去needle的字符个数j(因为已经遍历完needle了,所以此时j就是结束标志的下标,也就是字符个数)就是第一个位置;而不相等的话就将i指向开始的字符的下一个,比如第一遍是i=0与j=0相比,如果不想等则让i=1与j=0相比,继续一个个找,不相等就i=2与j=0相比,进而得出一个式子i=i-j+1.最后判断此时的j是否指向needle结束标志,是的话代表needle遍历完,返回i-j;否则就代表不存在返回-1.

具体步骤:

1、利用strlen求出两个数组的总长度
2、定义i和j分别用以访问两个数组的每个字符
3、当两个数组都没遍历完时,在haystack数组中的第一个字符开始依次与needle的字符比较,一旦不等i就回溯下一首位,相当于i向右滑动一个字符的位置。相等则i++,j++看第二个字符是否相等
4、判断needle是否遍历完成,因为一旦不相等就让j=0,遍历完成返回i-j;否则返回-1。

思路可以参考数据结构(C语言版)第四章串的串匹配算法,其中包括了BF算法还有改进的KMP算法。串的模式匹配算法

三、具体代码

int strStr(char * haystack, char * needle){
    int n=strlen(haystack);
    int m=strlen(needle);
    int i=0,j=0;
    while(i<n&&j<m)
    {
        if(haystack[i]==needle[j])//如果字符相等,则比较下一位
        {
            i++;
            j++;
        }
        else//如果不相等,则j不变,i指向haystack数组的下一个字符
        {
            i=i-j+1;
            j=0;//如果有一个字符相等,但第二个不相等则重新与needle数组的第一个字符开始比较
        }
    }
    if(needle[j]=='\0')
     return i-j;//如果needle数组被遍历完,则代表needle在数组haystack中存在,则用目前i的位置-j就是第一个位置
    else
     return -1;//否则不存在
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

茄味琪琪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值