qq_31817667 2016-10-18 14:42 采纳率: 50%
浏览 1127
已采纳

关于KMP算法问题 跪求大神

#include
#include
#define MAXSIZE 20
char *String_Create()
{
char *s,ch;
int i=0;
s=(char *)malloc(sizeof(MAXSIZE));
ch=getchar();
while(ch!='\n')
{
*(s+i)=ch;
i++;
ch=getchar();
}
return s;
}
int String_Length(char *s)
{
int l=0;
while(*s!='\0')
{
l++;
s++;
}
return l;
}
int String_IndexKMP(char *d,char *s,int pos)
{
int i=pos,j=1,ld,ls;
ld=String_Length(d);
ls=String_Length(s);

int k=1,next[20],l=0;
next[1]=0;
while(k<ls)
{
    if(l==0||(s+k)==(s+l))
    {
        ++k;
        ++l;
        if((s+k)!=(s+l))
        next[k]=l;
        else
        next[k]=next[l];
     }
     else
     l=next[l];
 }

while(i<=ld&&j<=ls)
{
    if(j==0||(ld+i)==(ls+j))
    {
        ++i;
        ++j;
     }

     else
    j=next[j];
 }
 if(j>ls)
 return (i-ls);
 else
 return 0;

}
void String_Show(char *s)
{
while(putchar(*s++));
printf("\n");
}
int main()
{
char *str,*c;
int ans;
c=(char *)malloc(sizeof(MAXSIZE));
printf("请输入主串:");
str=String_Create();
printf("请输入子串:");
gets(c);
ans=String_IndexKMP(str,c,1);
printf("子串在主串中的位置为:%d",ans);
return 0;
}

  • 写回答

1条回答 默认 最新

  • threenewbee 2016-10-18 16:09
    关注
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的