力扣第13刷-实现 strStr()

简介: 力扣第13刷-实现 strStr()

Example 13

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

解题思路:让字符串needle(长度为m) 与字符串haystack 的所有长度为m 的子串均匹配一次。

如果当前子串匹配成功,我们返回当前子串的开始位置即可,如果所有子串都匹配失败,则返回−1。

解题步骤:

1. 定义变量needleLength与haystackLength分别记录两个字符串的长度。

2. 依次遍历haystack字符串中自0索引至haystackLength - needleLength索引为开始位置的长度为needleLength的字符串,若与needle相等,则将该索引返回,否则继续考察。

3. 遍历结束,说明没有符合条件的子串,则返回-1。

 

示例代码如下:

public class ImplementStrStr {
    /**
     * 实现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
     * 来源:力扣(LeetCode)
     * 链接:https://leetcode.cn/problems/implement-strstr
     */
    public static void main(String[] args) {
        ImplementStrStr iss = new ImplementStrStr();
        System.out.println(iss.strStr("hello", "ll")); // 2
    }
    /**
     * 网友
     * @param haystack
     * @param needle
     * @return
     */
    /*public int strStr(String haystack, String needle) {
        return haystack.indexOf(needle);
    }*/
    /**
     * 个人
     *
     * @param haystack
     * @param needle
     * @return
     */
    public int strStr(String haystack, String needle) {
        int needleLength = needle.length();
        int haystackLength = haystack.length();
        for (int i = 0; i <= haystackLength - needleLength; i++) {
            if (haystack.substring(i, i + needleLength).equals(needle)) return i;
        }
        return -1;
    }
    /**
     * 官方
     * @param haystack
     * @param needle
     * @return
     */
    /*public int strStr(String haystack, String needle) {
        int n = haystack.length(), m = needle.length();
        for (int i = 0; i + m <= n; i++) {
            boolean flag = true;
            for (int j = 0; j < m; j++) {
                if (haystack.charAt(i + j) != needle.charAt(j)) {
                    flag = false;
                    break;
                }
            }
            if (flag) {
                return i;
            }
        }
        return -1;
    }*/
}
相关文章
|
7月前
|
算法 C++ 索引
leetcode-28:实现 strStr()(字符串匹配,暴力匹配算法和KMP算法)
leetcode-28:实现 strStr()(字符串匹配,暴力匹配算法和KMP算法)
81 0
|
2月前
【LeetCode 21】28. 实现 strStr()
【LeetCode 21】28. 实现 strStr()
34 0
|
6月前
|
SQL 算法 数据可视化
Leetcode第28题:实现 strStr()【python】
Leetcode第28题:实现 strStr()【python】
LeetCode-28 实现strStr() KMP算法的学习
LeetCode-28 实现strStr() KMP算法的学习
|
算法 安全 Java
LeetCode - #28 实现 strStr()
不积跬步,无以至千里;不积小流,无以成江海,Swift社区 伴你前行。如果大家有建议和意见欢迎在文末留言,我们会尽力满足大家的需求。
|
算法 Java C语言
leetcode:28.实现strStr()
给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始)。如果不存在,则返回 -1。
79 0
leetcode 28 找出字符串第一个匹配的下标(KMP实现strStr)
leetcode 28 找出字符串第一个匹配的下标(KMP实现strStr)
91 0
leetcode 28 找出字符串第一个匹配的下标(KMP实现strStr)
|
存储 前端开发 算法
一行代码解决LeetCode实现 strStr()使用JavaScript解题|前端学算法
一行代码解决LeetCode实现 strStr()使用JavaScript解题|前端学算法
165 0
一行代码解决LeetCode实现 strStr()使用JavaScript解题|前端学算法
|
存储 算法 索引
代码随想录刷题|LeetCode KMP算法理论 28. 实现 strStr() 459.重复的子字符串
代码随想录刷题|LeetCode KMP算法理论 28. 实现 strStr() 459.重复的子字符串
代码随想录刷题|LeetCode KMP算法理论 28. 实现 strStr() 459.重复的子字符串
KMP - leetcode28. 实现 strStr()
快速学习 KMP - leetcode28. 实现 strStr()
KMP - leetcode28. 实现 strStr()