實現strStr()

實現strStr()

描述

實現 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() 定義相符。

思路

  • needle空串時返回0
  • 遍歷haystack字符串,判定當前字符與needle字符是否相同,不同則繼續遍歷
  • 若與needle字符相同,則匹配剩餘字符是否相同,needle遍歷結束,返回匹配位置,haystack遍歷結束,返回-1,發現不匹配字符,跳出來繼續匹配首字符
  • haystack遍歷完成仍未匹配完成,返回-1
int strStr(char * haystack, char * needle) {
    if(strlen(needle) == 0)
        return 0;
    for(int i=0;haystack[i] != '\0';i++) {//遍歷字符串
        if(needle[0] == haystack[i]) {//查找首字符匹配
            for(int j=0;;j++) {//剩餘字符匹配
                if(needle[j] == '\0')
                    return i; 
                if(haystack[i+j] == '\0')
                    return -1;
                if(needle[j] != haystack[i+j]) //剩餘字符不匹配
                    break;//跳出當前匹配  
            }
            continue;//查找下一首字符
        }
    }
    return -1;//首字符未匹配成功
}

注意

  • 匹配時的返回條件檢測順序有嚴格要求,needle匹配完成返回成功,needle匹配未完成而haystack遍歷完成返回-1,最後纔是判定是否匹配
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章