ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Go实现KMP和Sunday算法

2022-06-06 18:00:21  阅读:342  来源: 互联网

标签:return int len substr Sunday subLen str KMP Go


KMP

 1 func KMP(str, substr string) int {
 2    if substr == "" {
 3       return 0
 4    }
 5    strLen := len(str)
 6    subLen := len(substr)
 7    next := make([]int, subLen)
 8    for i, j := 1, 0; i < subLen; i++ {
 9       for j > 0 && substr[i] != substr[j] {
10          j = next[j-1]
11       }
12       if substr[i] == substr[j] {
13          j++
14       }
15       next[i] = j
16    }
17    for i, j := 0, 0; i < strLen; i++ {
18       for j > 0 && str[i] != substr[j] {
19          j = next[j-1]
20       }
21       if str[i] == substr[j] {
22          j++
23       }
24       if j == subLen {
25          return i - subLen + 1
26       }
27    }
28    return -1
29 }

Sunday

func Sunday(str, substr string) int {
   if len(substr) == 0 {
      return 0
   }
   strLen := len(str)
   subLen := len(substr)
   if subLen > strLen {
      return -1
   }
   m := make(map[rune]int, 0)
   for index, c := range substr {
      m[c] = index
   }
   start, compareCount := 0, 0
   for start+subLen <= strLen {
      compareCount = 0
      for str[start+compareCount] == substr[compareCount] {
         compareCount++
         if compareCount == subLen {
            return start
         }
      }
      checkIndex := start + subLen
      var lastIndex int
      if checkIndex < strLen {
         lastIndex = m[rune(str[checkIndex])]
      } else {
         lastIndex = -1
      }
      if lastIndex != -1 {
         start += subLen - lastIndex
      } else {
         start += start + subLen + 1
      }
   }
   return -1
}

  

标签:return,int,len,substr,Sunday,subLen,str,KMP,Go
来源: https://www.cnblogs.com/chenjianhui254/p/16349163.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有