温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C++的KMP算法是怎么用的

发布时间:2021-08-16 09:36:14 来源:亿速云 阅读:166 作者:chen 栏目:开发技术

这篇文章主要讲解了“C++的KMP算法是怎么用的”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++的KMP算法是怎么用的”吧!

目录
  • KMP算法

    • 步骤1:先计算子串中的前后缀数组Next

      • C++代码:

    • 步骤2:查找子串在母串中出现的位置。

    • 总结

      KMP算法

      KMP算法作用:字符串匹配

      例如母串S = “aaagoogleaaa”;

      子串T= “google”;

      步骤1:先计算子串中的前后缀数组Next

      google
      next[0]next[1]next[2]next[3]next[4]next[5]
      -100010
      C++代码:
      //步骤1: void GetNext(string Tsub, vector<int>& Next) {     int j = 0, k = -1;     Next[0] = k;     while (j < Tsub.length() - 1)     {         if (k == -1 || Tsub[j] == Tsub[k])         {             Next[++j] = ++k;         }         else         {             k = Next[k];         }     } }

      步骤2:查找子串在母串中出现的位置。

      //步骤2: int KMP(string S, string T, vector<int> Next) {     int i = 0, j = 0;     int m = S.length();     int n = T.length();     while (i < m && j < n)     {         if (j == -1 || S[i] == T[j])         {             i++;             j++;         }         else         {             j = Next[j];         }     }     if (j == n)     {         return i - j;     }     else     {         return -1;     } }

      结合上面两个步骤写出完整代码:

      #include <iostream> #include <vector> using namespace std; //步骤1: void GetNext(string Tsub, vector<int>& Next) {     int j = 0, k = -1;     Next[0] = k;     while (j < Tsub.length() - 1)     {         if (k == -1 || Tsub[j] == Tsub[k])         {             Next[++j] = ++k;         }         else         {             k = Next[k];         }     } } //步骤2: int KMP(string S, string T, vector<int> Next) {     int i = 0, j = 0;     int m = S.length();     int n = T.length();     while (i < m && j < n)     {         if (j == -1 || S[i] == T[j])         {             i++;             j++;         }         else         {             j = Next[j];         }     }     if (j == n)     {         return i - j;     }     else     {         return -1;     } } int main() {     string S = "aaagoogleaaa";     string T = "google";     vector<int> Next(T.length());     GetNext(T, Next);     int retVal = KMP(S, T, Next);     if (retVal == -1)     {         std::cout << "can't Index" << std::endl;     }     else     {         std::cout << "Index :" << retVal << std::endl;     }     return 0; }

      感谢各位的阅读,以上就是“C++的KMP算法是怎么用的”的内容了,经过本文的学习后,相信大家对C++的KMP算法是怎么用的这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

      向AI问一下细节

      免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

      c++
      AI