LeetCode #28 Implement strStr() 實(shí)現(xiàn)strStr()

28 Implement strStr() 實(shí)現(xiàn)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().

題目描述:
實(shí)現(xiàn) strStr() 函數(shù)。

給定一個(gè) haystack 字符串和一個(gè) needle 字符串唆阿,在 haystack 字符串中找出 needle 字符串出現(xiàn)的第一個(gè)位置 (從0開始)益涧。如果不存在,則返回 -1驯鳖。

示例:

示例 1:

輸入: haystack = "hello", needle = "ll"
輸出: 2

示例 2:

輸入: haystack = "aaaaa", needle = "bba"
輸出: -1

說明:

當(dāng) needle 是空字符串時(shí)闲询,我們應(yīng)當(dāng)返回什么值呢久免?這是一個(gè)在面試中很好的問題。

對(duì)于本題而言扭弧,當(dāng) needle 是空字符串時(shí)我們應(yīng)當(dāng)返回 0 阎姥。這與C語言的 strstr() 以及 Java的 indexOf() 定義相符。

思路:

  1. 在每一個(gè)haystack字符上遍歷needle
    時(shí)間復(fù)雜度O(nm), 空間復(fù)雜度O(1), 其中n為haystack長(zhǎng)度, m為needle長(zhǎng)度
  2. KMP算法
    時(shí)間復(fù)雜度O(n), 空間復(fù)雜度O(m), 其中n為haystack長(zhǎng)度, m為needle長(zhǎng)度
  3. 當(dāng)然最偷懶的算法是直接調(diào)用strstr()(C++)/indexOf()(Java)

代碼:
C++:

class Solution 
{
private:
    // 求next數(shù)組
    void ComputePrefix(string s, int next[]) 
    {
        int len = s.length();
        // i為字符串下標(biāo), j為最大前/后綴長(zhǎng)度
        int i, j;
        // next數(shù)組初始一定為0, 即字符串第一個(gè)字符是沒有前/后綴的
        next[0] = 0;
        // 從第二個(gè)字符開始求取next數(shù)組
        for (i = 0, j = 1; j < len; j++) 
        {
            // 求取s[0]~s[j]相同的前/后綴長(zhǎng)度
            /* 例子:
               "AB"
               前綴為["A"]
               后綴為["B"]
               無相同元素, 長(zhǎng)度為0
               "ABCDAB"
               前綴為["A", "AB", "ABC", "ABCD", "ABCDA"]
               后綴為["BCDAB", "CDAB", "DAB", "AB", "B"]
               相同的元素為 "AB", 長(zhǎng)度為2
            */
            /* i > 0, 是因?yàn)榈谝粋€(gè)字符是沒有前/后綴的
               而且查找失敗, i要退回next[i - 1]
            */
            /* 對(duì)于已經(jīng)求取的next[j] = i, 表示在字符串下標(biāo)為 j處有長(zhǎng)度為 i的前/后綴相等
               比如 A -> AB
               即 next[0] = 0
               對(duì)下次while循環(huán), 直接跳出
               ABCDA -> ABCDAB
               可以得到有一個(gè)前/后綴相等
               即next[4] = 1
               即
               ABCD A
                    |
                    A BCDA
               此時(shí) next[4] = 1, j = 4, i = 1
               ABCD AB
                    ||
                    AB CDAB
               此時(shí) 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
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末鸽捻,一起剝皮案震驚了整個(gè)濱河市丁寄,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌泊愧,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,104評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件盛正,死亡現(xiàn)場(chǎng)離奇詭異删咱,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)豪筝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門痰滋,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人续崖,你說我怎么就攤上這事敲街。” “怎么了严望?”我有些...
    開封第一講書人閱讀 168,697評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵多艇,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我像吻,道長(zhǎng)峻黍,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,836評(píng)論 1 298
  • 正文 為了忘掉前任拨匆,我火速辦了婚禮姆涩,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘惭每。我一直安慰自己骨饿,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,851評(píng)論 6 397
  • 文/花漫 我一把揭開白布台腥。 她就那樣靜靜地躺著宏赘,像睡著了一般。 火紅的嫁衣襯著肌膚如雪览爵。 梳的紋絲不亂的頭發(fā)上置鼻,一...
    開封第一講書人閱讀 52,441評(píng)論 1 310
  • 那天,我揣著相機(jī)與錄音蜓竹,去河邊找鬼箕母。 笑死储藐,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的嘶是。 我是一名探鬼主播钙勃,決...
    沈念sama閱讀 40,992評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼聂喇!你這毒婦竟也來了辖源?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,899評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤希太,失蹤者是張志新(化名)和其女友劉穎克饶,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體誊辉,經(jīng)...
    沈念sama閱讀 46,457評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡矾湃,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,529評(píng)論 3 341
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了堕澄。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片邀跃。...
    茶點(diǎn)故事閱讀 40,664評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖蛙紫,靈堂內(nèi)的尸體忽然破棺而出拍屑,到底是詐尸還是另有隱情,我是刑警寧澤坑傅,帶...
    沈念sama閱讀 36,346評(píng)論 5 350
  • 正文 年R本政府宣布僵驰,位于F島的核電站,受9級(jí)特大地震影響裁蚁,放射性物質(zhì)發(fā)生泄漏矢渊。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,025評(píng)論 3 334
  • 文/蒙蒙 一枉证、第九天 我趴在偏房一處隱蔽的房頂上張望矮男。 院中可真熱鬧,春花似錦室谚、人聲如沸毡鉴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽猪瞬。三九已至,卻和暖如春入篮,著一層夾襖步出監(jiān)牢的瞬間陈瘦,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工潮售, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留痊项,地道東北人锅风。 一個(gè)月前我還...
    沈念sama閱讀 49,081評(píng)論 3 377
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像鞍泉,于是被迫代替她去往敵國(guó)和親皱埠。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,675評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容