https://leetcode.cn/problems/find-the-index-of-the-first-occurrence-in-a-string/
题面
实现 strStr() 函数。
给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始)。如果不存在,则返回 -1。
示例 1: 输入: haystack = “hello”, needle = “ll” 输出: 2
示例 2: 输入: haystack = “aaaaa”, needle = “bba” 输出: -1
说明: 当 needle 是空字符串时,我们应当返回什么值呢?这是一个在面试中很好的问题。 对于本题而言,当 needle 是空字符串时我们应当返回 0 。这与C语言的 strstr() 以及 Java的 indexOf() 定义相符。
思路 KMP,时间O(n+m),空间O(m)
KMP经典例题。
实现① 前缀表不减一
C++
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
| public: void getNext(int* next, const string& s) { int j = 0; next[0] = 0; for (int i = 1; i < s.size(); i++) { while (j > 0 && s[i] != s[j]) j = next[j - 1]; if (s[i] == s[j]) j++; next[i] = j; } int strStr(string haystack, string needle) { if (needle.size() == 0) return 0; vector<int> next(needle.size()); getNext(&next[0], needle); int j = 0; for (int i = 0; i < haystack.size(); i++) { while (j > 0 && haystack[i] != needle[j]) j = next[j - 1]; if (haystack[i] == needle[j]) j++; if (j == needle.size()) return i - needle.size() + 1; } return -1; } }
|
Java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
| public int strStr(String haystack, String needle) { if (needle.length() == 0) return 0; int[] next = new int[needle.length()]; getNext(next, needle); int j = 0; for (int i = 0; i < haystack.length(); i++) { while (j > 0 && needle.charAt(j) != haystack.charAt(i)) j = next[j - 1]; if (needle.charAt(j) == haystack.charAt(i)) j++; if (j == needle.length()) return i - needle.length() + 1; } return -1; }
private void getNext(int[] next, String s) { int j = 0; next[0] = 0; for (int i = 1; i < s.length(); i++) { while (j > 0 && s.charAt(j) != s.charAt(i)) j = next[j - 1]; if (s.charAt(j) == s.charAt(i)) j++; next[i] = j; } }
|
实现② 前缀表减一
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
| public void getNext(int[] next, String s) { int j = -1; next[0] = j; for (int i = 1; i < s.length(); i++) { while (j >= 0 && s.charAt(i) != s.charAt(j + 1)) j = next[j]; if (s.charAt(i) == s.charAt(j + 1)) j++; next[i] = j; } } public int strStr(String haystack, String needle) { if (needle.length() == 0) return 0; int[] next = new int[needle.length()]; getNext(next, needle); int j = -1; for (int i = 0; i < haystack.length(); i++) { while (j >= 0 && haystack.charAt(i) != needle.charAt(j + 1)) j = next[j]; if (haystack.charAt(i) == needle.charAt(j + 1)) j++; if (j == needle.length() - 1) return (i - needle.length() + 1); } return -1; }
|