源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2020-12-08 00:24 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:C++ 数据结构之kmp算法中的求Next()函数的算法
[b]C++ 数据结构之kmp算法中的求Next()函数的算法[/b] 实例代码:

#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;
}
[img]http://files.jb51.net/file_images/article/201706/2017625113310384.png?2017525113328[/img] 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部