LeetCode【28、实现strStr()】(简单)

245 阅读1分钟

问题描述

这是 LeetCode 上的 28. 实现 strStr(),难度为 简单

关键字: 字符串KMP(我暂时还不会)

实现 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

提示:

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

暴力解法

遍历 原串 中每个字符作为 初始字符,然后 从原串的初始字符开始与目标字符串的每个字符进行匹配。

  1. 完全一致匹配:返回当前的字符。
  2. 匹配失败:原串的下一个字符作为 初始字符,重新进行匹配。
class Solution {
    public int strStr(String haystack, String needle) {
        if (needle.isEmpty()) {
            return 0;
        }
        int h = haystack.length(), n = needle.length();
        char[] hs = haystack.toCharArray(), ns = needle.toCharArray();
        // 从 0 遍历到 原串与目标串的差值,即去掉目标串剩下的字符串长度
        for (int i = 0; i <= h - n; i++) {
            int a = i, b = 0;
            // 一个字符一个字符判断
            while(b < n && hs[a] == ns[b]) {
                ++a;
                ++b;
            }
            // 如果完全一致,返回当前
            if (b == n) {
                return i;
            }
        }
        // 其他返回失败
        return -1;
    }
}

KMP算法

暂时不太会,以后补充!!!


引用

我的 github 仓库已经同步建立,github.com/haonange131…