今天就跟大家聊聊有關kmp怎樣實現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() 定義相符
解題思路:
1,用暴力解法,時間復雜度是O(mn)
2,使用kmp算法是用空間換時間,用O(m)的空間可以獲得O(m+n)的時間復雜度
3,next數組的作用:記錄當前的后綴字串與前綴子串最大匹配長度。已經比較過的地方可以不用比較
4,思想和dp很像,但是空間復雜度O(m)比dp O(mn)低
代碼實現
func strStr(haystack string, needle string) int {
if haystack==needle || needle==""{
return 0
}
if len(needle)==0{
return -1
}
next:=getNext(needle)
m:=0
for i:=0;i<len(haystack);i++{
for m>0 && haystack[i]!=needle[m]{
m=next[m-1]
}
if haystack[i]==needle[m]{
m++
if m==len(needle){
return i-m+1
}
}
}
return -1
}
func getNext(needle string)[]int{
next:=make([]int,len(needle))
i:=0
for j:=1;j<len(needle);j++{
for i>0 && needle[i]!=needle[j]{
i=next[i-1]
}
if needle[j]==needle[i]{
i++
}
next[j]=i
}
return next
}
看完上述內容,你們對kmp怎樣實現strstr() 函數有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注創新互聯行業資訊頻道,感謝大家的支持。
新聞標題:kmp怎樣實現strstr()函數
路徑分享:http://vcdvsql.cn/article22/podpjc.html
成都網站建設公司_創新互聯,為您提供網站設計公司、、域名注冊、建站公司、軟件開發、網站排名
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯