LeetCode #28 Implement strStr() 实现strStr()

28 Implement strStr() 实现strStr()

Description:
Implement strStr().

Return the index of the first occurrence of needle in haystack, or -1 if needle is not part of haystack.

Example:

Example 1:

Input: haystack = "hello", needle = "ll"
Output: 2

Example 2:

Input: haystack = "aaaaa", needle = "bba"
Output: -1

Clarification:

What should we return when needle is an empty string? This is a great question to ask during an interview.

For the purpose of this problem, we will return 0 when needle is an empty string. This is consistent to C's strstr() and Java's indexOf().

题目描述:
实现 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() 定义相符。

思路:

  1. 在每一个haystack字符上遍历needle
    时间复杂度O(nm), 空间复杂度O(1), 其中n为haystack长度, m为needle长度
  2. KMP算法
    时间复杂度O(n), 空间复杂度O(m), 其中n为haystack长度, m为needle长度
  3. 当然最偷懒的算法是直接调用strstr()(C++)/indexOf()(Java)

代码:
C++:

class Solution 
{
private:
    // 求next数组
    void ComputePrefix(string s, int next[]) 
    {
        int len = s.length();
        // i为字符串下标, j为最大前/后缀长度
        int i, j;
        // next数组初始一定为0, 即字符串第一个字符是没有前/后缀的
        next[0] = 0;
        // 从第二个字符开始求取next数组
        for (i = 0, j = 1; j < len; j++) 
        {
            // 求取s[0]~s[j]相同的前/后缀长度
            /* 例子:
               "AB"
               前缀为["A"]
               后缀为["B"]
               无相同元素, 长度为0
               "ABCDAB"
               前缀为["A", "AB", "ABC", "ABCD", "ABCDA"]
               后缀为["BCDAB", "CDAB", "DAB", "AB", "B"]
               相同的元素为 "AB", 长度为2
            */
            /* i > 0, 是因为第一个字符是没有前/后缀的
               而且查找失败, i要退回next[i - 1]
            */
            /* 对于已经求取的next[j] = i, 表示在字符串下标为 j处有长度为 i的前/后缀相等
               比如 A -> AB
               即 next[0] = 0
               对下次while循环, 直接跳出
               ABCDA -> ABCDAB
               可以得到有一个前/后缀相等
               即next[4] = 1
               即
               ABCD A
                    |
                    A BCDA
               此时 next[4] = 1, j = 4, i = 1
               ABCD AB
                    ||
                    AB CDAB
               此时 next[5] = 2, j = 5, i = 2
            */
            // 每次查找不匹配, i退回next[i - 1]
            while (i > 0 and s[i] != s[j]) i = next[i - 1];
            if (s[i] == s[j]) i++;
            next[j] = i;
        }
    }
 public:
 int strStr(string haystack, string needle) 
    {
        if (!needle.length()) return 0;
        if (!haystack.length()) return -1;
        int next[needle.length()];
        ComputePrefix(needle, next);
        int j = 0;
        for (int i = 0; i < haystack.length(); i++) 
        {
            // 每次查找不匹配, j退回next[j - 1]
            while (j > 0 and needle[j] != haystack[i]) j = next[j - 1];
            if (needle[j] == haystack[i]) j++;
            if (j == needle.length()) return i - j + 1;
        }
        return -1;
    }
};

Java:

class Solution {
    public int strStr(String haystack, String needle) {
        return haystack.indexOf(needle);
    }
}

Python:

class Solution:
    def strStr(self, haystack: str, needle: str) -> int:
        if not needle:
            return 0
        for i in range(len(haystack)):
            j = i + len(needle)
            if j <= len(haystack) and haystack[i:j] == needle:
                return i
        return -1
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容