面试经典150题——找出字符串中第一个匹配项的下标

面试经典150题 day23

      • 题目来源
      • 我的题解
        • [方法一 库函数](#方法一 库函数)
        • [方法二 自定义indexOf函数](#方法二 自定义indexOf函数)
        • [方法三 KMP算法](#方法三 KMP算法)

题目来源

力扣每日一题;题序:28

我的题解

方法一 库函数

直接使用indexOf函数。
时间复杂度 :O(n)
空间复杂度:O(1)

java 复制代码
public int strStr(String haystack, String needle) {
    return haystack.indexOf(needle);
}
方法二 自定义indexOf函数

每次找到needle开始字符匹配的位置,然后从该位置开始判断是否能够生成needle字符串。
时间复杂度:O(nm)。外层循环遍历了 haystack 字符串的每个字符,内层循环则在 needle 字符串的长度范围内进行比较。因此,时间复杂度为 O(n m),其中 n 是 haystack 字符串的长度,m 是 needle 字符串的长度。

空间复杂度:O(1)

java 复制代码
public int strStr(String haystack, String needle) {
    int n=haystack.length();
    for(int i=0;i<=n-needle.length();i++){
        if(haystack.charAt(i)==needle.charAt(0)&&indexOf(haystack,needle,i)){
            return i;
        }
    }
    return -1;
}
public boolean indexOf(String haystack,String needle,int start){
    int n=needle.length();
    int i=0;
    while(i+start<haystack.length()&&i<n&&haystack.charAt(i+start)==needle.charAt(i))
        i++;
    return i==n?true:false;
}
方法三 KMP算法

KMP算法详情参见:宫水三叶
时间复杂度:O(n+m)。其中 n 是字符串 haystack 的长度,m 是字符串 needle 的长度。至多需要遍历两字符串一次。

空间复杂度:O(m)

java 复制代码
public int strStr(String haystack, String needle) {
    return KMP(haystack,needle);
}
public int KMP(String haystack,String needle){
    int m=haystack.length();
    int n=needle.length();
    if(needle==null||n==0)
        return 0;
    int next[]=new int[n];
    char need[]=needle.toCharArray();
    int i=1,j=0;
    // 构造next数组
    while(i<n){
    	//
        if(need[i]==need[j]){
            j+=1;
            next[i]=j;
            i++;
        }else{
            if(j==0){
                next[i]=0;
                i++;
            }else{
                j=next[j-1];
            }
        }
    }

    i=0;
    j=0;
    char hay[]=haystack.toCharArray();
    while(i<m){
        if(hay[i]==need[j]){
            i++;
            j++;
        }else{
            if(j==0){
                i++;
            }else{
                j=next[j-1];
            }
        }
        if(j==n)
            return i-j;
    }
    return -1;
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

相关推荐
IT学长编程5 分钟前
计算机毕业设计 Java酷听音乐系统的设计与实现 Java实战项目 附源码+文档+视频讲解
java·spring boot·毕业设计·课程设计·毕业论文·音乐系统·计算机毕业设计选题
IT学长编程22 分钟前
计算机毕业设计 基于协同过滤算法的个性化音乐推荐系统的设计与实现 Java实战项目 附源码+文档+视频讲解
java·spring boot·毕业设计·毕业论文·协同过滤算法·计算机毕业设计选题·个性化音乐推荐系统
希望有朝一日能如愿以偿24 分钟前
力扣题解(飞机座位分配概率)
算法·leetcode·职场和发展
小小娥子27 分钟前
Redis的基础认识与在ubuntu上的安装教程
java·数据库·redis·缓存
Espresso Macchiato32 分钟前
Leetcode 3306. Count of Substrings Containing Every Vowel and K Consonants II
leetcode·滑动窗口·leetcode medium·leetcode 3306·leetcode周赛417
几何心凉35 分钟前
已解决:org.springframework.web.HttpMediaTypeNotAcceptableException
java
丶Darling.36 分钟前
代码随想录 | Day26 | 二叉树:二叉搜索树中的插入操作&&删除二叉搜索树中的节点&&修剪二叉搜索树
开发语言·数据结构·c++·笔记·学习·算法
华农第一蒟蒻37 分钟前
Java中JWT(JSON Web Token)的运用
java·前端·spring boot·json·token
两点王爷39 分钟前
使用WebClient 快速发起请求(不使用WebClientUtils工具类)
java·网络
JustCouvrir39 分钟前
代码随想录算法训练营Day15
算法