前端Leetcode系列|28. 实现 strStr()

364 阅读2分钟

这是我参与8月更文挑战的第12天,活动详情查看:8月更文挑战

这是力扣系列第4篇,今天来和小伙伴们一起打卡力扣第28题:实现 strStr()。

前往Leetcode专栏系列文章,查看解锁更多内容。

一、题目描述

实现 strStr() 函数。

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

说明:

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

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

  示例 1:

输入:haystack = "hello", needle = "ll"
输出:2

示例 2:

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

示例 3:

输入:haystack = "", needle = ""
输出:0

提示:

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

来源:力扣(LeetCode) 链接:leetcode-cn.com/problems/im… 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

二、思路分析

拿到这个题目,可以先来判断,如果要查找的字符串为空,则直接返回0 即可,如果不为空则继续执行。

定义两个常量n,m,分别代表haystack的长度及needle的长度,写一个从0开始的for循环,循环满足的条件为当前下标加上要查找的字符串总长度小于等于全部字符总长度,即i + m <= n

在循环中定义一个变量flagtrue,再在循环中写一个循环,来判断两项的值是否相等,若有判断到不相等,则将flag设置为false,跳出循环体,并返回-1。否则遍历完之后拿到下标,直接返回即可。

三、JavaScript实现代码

/**
 * @param {string} haystack 全部字符
 * @param {string} needle 要查找的字符
 * @return {number} 下标
 */
var strStr = function (haystack, needle) {
    if (needle.length === '') {
        return 0;
    }
    const n = haystack.length, m = needle.length;
    for (let i = 0; i + m <= n; i++) {
        let flag = true;
        for (let j = 0; j < m; j++) {
            if (haystack[i + j] != needle[j]) {
                flag = false;
                break;
            }
        }
        if (flag) {
            return i;
        }
    }
    return -1;
};

四、总结

前端漫漫长途,我们都在路上,希望可以和小伙伴们一起交流,一起进步。持续更新ing.....