實現strStr()

 

實現strStr()

描述

實現 strStr() 函數。html

給定一個 haystack 字符串和一個 needle 字符串,在 haystack 字符串中找出 needle 字符串出現的第一個位置 (從0開始)。若是不存在,則返回 -1java

示例 1:面試

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

示例 2:api

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

說明:oracle

needle 是空字符串時,咱們應當返回什麼值呢?這是一個在面試中很好的問題。函數

對於本題而言,當 needle 是空字符串時咱們應當返回 0 。這與C語言的 strstr() 以及 Java的 indexOf() 定義相符。spa

思路

  • 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,最後纔是斷定是否匹配
相關文章
相關標籤/搜索