AetherZhao 2016-10-01 06:28 采纳率: 33.3%
浏览 902
已采纳

这个代码怎么调试啊,运行不了

#include
typedef struct
{
char *ch;
int len;

}st;//字符串结构定义

void getnext(st substr,int next[])//覆盖函数
{
int i=0,j=-1;
next[0]=-1;
while (i<substr.len)
{
if(j==-1||substr.ch[i]==substr.ch[j])
{
next[++i]=++j;
}
else
j=next[j];

}

}
//以下是主要算法-kmp
int kmp(st str,st substr,int next[])
{
int i=0,j=0;
while (i<str.len && j<substr.len)
{
if(str.ch[i]==substr.ch[j])
{
++i;
++j;
}
else
{
j=next[j];
if(j==-1)
{
j=0;
++i;
}
}

}
if (j==substr.len)
return i-substr.len;
else return -1;

}
//主函数
int main()
{
int next[100];
int position;
st str;
st substr;
puts("请输入一段文章:");
gets(str.ch);
puts("请输入您想找到的一段文字:");
gets(substr.ch);
getnext(substr,next);
position = kmp(str,substr,next);
if(position!=-1)
printf("%d",position);
else
puts("error");

}


  • 写回答

2条回答 默认 最新

  • leewers 2016-10-01 10:10
    关注

    两个问题
    1.在结构体中只定义了一个char指针而不是char数组,既然是指针却又没有在main函数中给其分配内存就直接使用gets函数试图写入内存,导致程序崩溃。

    //解决方法一: 直接将ch定义为char数组,至于大小看情况自行修改
    typedef struct
    {
    char ch[100];
    int len;
    }st;//字符串结构定义
    
    //解决方法二: 在main函数中动态分配内存后再使用gets函数
    
    
    1. str和substr的len在获取输入后都没有赋值,导致getnext函数中数组越界,程序崩溃 加上这两句就行了(头文件string.h)
    str.len = strlen(str.ch);
    substr.len = strlen(substr.ch);
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥500 把面具戴到人脸上,请大家贡献智慧
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
  • ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
  • ¥30 c#打开word开启修订并实时显示批注
  • ¥15 如何解决ldsc的这条报错/index error
  • ¥15 VS2022+WDK驱动开发环境
  • ¥30 关于#java#的问题,请各位专家解答!
  • ¥30 vue+element根据数据循环生成多个table,如何实现最后一列 平均分合并
  • ¥20 pcf8563时钟芯片不启振
  • ¥20 pip2.40更新pip2.43时报错