用户注册



邮箱:

密码:

用户登录


邮箱:

密码:
记住登录一个月忘记密码?

发表随想


还能输入:200字
云代码 - c代码库

KMP算法实现

2016-06-27 作者: 一亿光年的距离举报

[c]代码库

void get_nextval(char s[],int nextval[])//求模式串S的nextval函数值并存入到nextval[]中
{
   int i=0,j=-1;
   nextval[0]=-1;
   while(i<strlen(s))
  {
     if(j==-1||s[i]==s[j])
     {
      ++i;  ++j;
     if(s[i]!=s[j])
       nextval[i]=j;
      else
       nextval[i]=nextval[j];
     }
  else
    j=nextval[j];
  }
}

int KMP(char s[],char t[],int nextval[])//利用模式串t的nextval函数求t的主串s
{
   int ls=strlen(s);
   int lt=strlen(t);
   int i=0,j=0,len=0;

   while(i<=ls&&j<=lt)
   {
     if(j==-1||s[i]==t[j])//继续比较后继字符
      {  ++i;  ++j; }
     else
      j=nextval[j]; //  模式串向右移动
     if(j==lt)//通过nextval[]求得的j如果和模式串的长度相等就说明模式串在主串中出现了;
     {
      len++;
      j=nextval[j];
     }
   }
   return len;
}


网友评论    (发表评论)


发表评论:

评论须知:

  • 1、评论每次加2分,每天上限为30;
  • 2、请文明用语,共同创建干净的技术交流环境;
  • 3、若被发现提交非法信息,评论将会被删除,并且给予扣分处理,严重者给予封号处理;
  • 4、请勿发布广告信息或其他无关评论,否则将会删除评论并扣分,严重者给予封号处理。


扫码下载

加载中,请稍后...

输入口令后可复制整站源码

加载中,请稍后...