欢迎来到代码驿站!

C代码

当前位置:首页 > 软件编程 > C代码

C++ 数据结构之kmp算法中的求Next()函数的算法

时间:2021-06-30 09:20:07|栏目:C代码|点击:

C++ 数据结构之kmp算法中的求Next()函数的算法

实例代码:


#include <iostream>
 
using namespace std;
 
void preKmp(char *c, int m, int Next[])
{
  int i=1,j=-1;
  Next[0]=-2;
  while(i<m)
  {
    if(j==-2)
     {
       Next[i]=-1;
       i++;
       j=-1;
     }
 
     ++j;
     if(i==m)
     return;
    if(c[i]==c[j])
     {
       Next[i]=j;
       ++i;
     }
    else if(j==0)
     {
       j=-2;
 
     }
    else j=Next[j-1];
  }
}
int main()
{
  cout << "Hello world!" << endl;
  char pat[12]="actabactace";
  int next[11];
  preKmp(pat,11,next);
  for(int i=0;i<11;i++)
    cout<<"next["<<i<<"]="<<next[i]<<endl;
  return 0;
}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

上一篇:深入C++浮点数无效值定义与判定的解决办法

栏    目:C代码

下一篇:浅谈CMake配置OpenCV 时静态链接与动态链接的选择

本文标题:C++ 数据结构之kmp算法中的求Next()函数的算法

本文地址:http://www.codeinn.net/misctech/150116.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有