找出字符串中第一个匹配项的下标

编程入门 行业动态 更新时间:2024-10-25 00:24:38

找出字符串中第一个匹配项的<a href=https://www.elefans.com/category/jswz/34/1770054.html style=下标"/>

找出字符串中第一个匹配项的下标

题目链接

找出字符串中第一个匹配项的下标

题目描述

注意点

  • haystack 和 needle 仅由小写英文字符组成

解答思路

  • 使用KMP算法,相比于普通地将整个字符串分成多块大小为needle.length()的子串找到第一个与needle匹配的子串,其可以在判断出任意一个子串不是匹配项时,无需从haystack下一位和needle第一位开始判断,而是根据needle中相同的前缀,直接排除一定不是匹配项的下标,转而从有可能匹配的位置开始判断,其时间复杂度相比于O(mn)缩短到了O(m + n)
  • KMP算法第一个关键点在于找到needle中相同的前缀,其思路为:建立两个指针i = 1,j = 0,遍历needle,如果i和j处的字符相同,则next[i] = j,且将i和j都向右移动一位;如果i和j处的字符不同,则将j移动至next[j - 1]处,直到i和j处的字符相同或j = 0为止,示例如abeabeabg对应的next数组为000123450
  • KMP算法第二个关键点在于根据next优化查询匹配项的步骤,其思路为:建立两个指针i = 0,k = 0,遍历haystack,如果i和k处的字符相同,则将i和k都向右移动一位;如果i和j处的字符不同,则将k移动至next[k - 1]处,直到i和k处的字符相同或k = 0为止,其保证排除掉一定不是匹配项的下标。示例如在abeabeabeabeabg找到abeabeabg,其会在i = 8,k = 8时判断出当前子串不匹配,随后将指针k移动至5,从指针i = 9,k = 6再一次开启匹配项的判断

代码

class Solution {public int strStr(String haystack, String needle) {// abeabeabeabeabg// abeabeabg// 000123450int m = haystack.length();int n = needle.length();if (n > m) {return -1;}// 找到needle中相同的前缀int[] next = new int[n];int j = 0;for (int i = 1; i < n; i++) {// needle[i] != needle[j],则j = next[j - 1],直到j = 0或needle[i] = needle[j]为止while(j > 0 && needle.charAt(i) != needle.charAt(j)) {j = next[j - 1];}// needle[i] = needle[j],next[i] = j + 1,i++,j++if (needle.charAt(i) == needle.charAt(j)) {j++;next[i] = j;} else {next[i] = 0;}}int k = 0;for (int i = 0; i < m; i++) {while (k > 0 && haystack.charAt(i) != needle.charAt(k)) {k = next[k - 1];}if (haystack.charAt(i) == needle.charAt(k)) {k++;}if (k == n) {return i - k + 1;}}return -1;}
}

关键点

  • KMP算法的思想
  • 注意边界问题

更多推荐

找出字符串中第一个匹配项的下标

本文发布于:2023-12-08 00:19:29,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1672075.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:下标   第一个   字符串

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!