- 我的解题思路
- 代码
- 时间复杂度
实现 strStr() 函数。
给你两个字符串 haystack 和 needle ,请你在 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 仅由小写英文字符组成
这题一看就是应该用KMP算法,先去看一下KMP算法。
KMP算法理解还是能理解的,但是那个球next数组的算法还没看懂,第一遍,先背过了。
class Solution {
public int strStr(String haystack, String needle) {
int m = haystack.length();
int n = needle.length();
if (n == 0) {
return 0;
}
int[] next = getNext(needle);
for (int i = 0, j = 0; i < m; i++) {
while (j > 0 && haystack.charAt(i) != needle.charAt(j)) {
j = next[j- 1];
}
if (haystack.charAt(i) == needle.charAt(j)) {
j++;
}
if (j == n) {
return i - n + 1;
}
}
return -1;
}
private int[] getNext(String pattern) {
int len = pattern.length();
int[] next = new int[len];
for (int i = 0, j = 1; j < len;j++) {
while (i > 0 && pattern.charAt(j) != pattern.charAt(i)) {
i = next[i-1];
}
if (pattern.charAt(j) == pattern.charAt(i)) {
i++;
}
next[j] = i;
}
return next;
}
}
时间复杂度
O(m+n)



