leetcode28.实现strStr()

本文解析了一位前端开发者自学如何在haystack中查找needle的实例,重点讲解了如何处理空needle情况,并分享了strStr函数的实现思路。通过这个过程,学习者展示了如何判断字符串空性、数组操作以及字符串匹配算法的应用。
摘要由CSDN通过智能技术生成

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

说明:

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

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

var strStr = function(haystack, needle) {
    if(haystack ==''||needle =='') return 0//判断字符串是否为空
    list1 = haystack.split('')
    list2 = needle.split('')
    let i,j=1,k=-1
    for(i=0;i<list1.length;i++){
        if(list2[0] == list1[i]){
            k=i
            if(list2.length == 1) return i
            while(j!=list2.length){
                if(list1[i+j]==list2[j]) j++
                else {
                    j=0
                    k=-1 
                    break
                }
            }
        }
        if(list2.length!=1&&j==list2.length) break
    }
    return j==list2.length?k:-1
};

对于此题我的思路是:

1、首先判断两个字符串是否为空,为空则返回0

2、将两个字符串转化为数组,方便比较

3、从haystack的第一项开始循环,判断needle的每一项否和它匹配,如果needle的长度唯一则直接返回下标即可

4、用k来记录下标的值

5、长度不为1的话继续判断之后的数,如果没有全部满足,则将j置为1,k置为-1

6、如果j等于needle的长度则代表找到了(这里加一个list2.length!=1是因为避开长度为一的时候但是第一此没有找出来的情况)

7、最后返回k的值即可

!!!!本人前端小白自学之路,欢迎各位大佬评论区指导,我会加以改良!!!!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值