鱼C论坛

 找回密码
 立即注册
查看: 2308|回复: 3

KMP生成字串数组时遇到了bug

[复制链接]
发表于 2019-4-24 20:48:01 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. void build_array(char* substr, int length)
  2. {
  3.        
  4.         int* sub_array = (int*)malloc((length+1)*sizeof(int));
  5.         for(int a=0; a<=length+1;a++)
  6.         {
  7.                     sub_array[a] = 0;
  8.         }
  9.         int i = 1;
  10.         int j = 0;
  11.         while(i<=length)
  12.         {
  13.                     if (substr[j]==substr[i])
  14.                     {
  15.                                 sub_array[i] ++;
  16.                                 i++;
  17.                                 j++;
  18.                     }
  19.                     else
  20.                     {
  21.                                 j = 0;
  22.                     }
  23.         }

  24.         //test the sub_array
  25.         printf("\nThe sub_array so far is :\n");
  26.         for(int k = 0; k<=length; k++)
  27.         {
  28.                     printf("%d ", sub_array[k]);
  29.         }
  30.         printf("\n");
  31.        
  32. }
复制代码
思路如下:

建立数组
    字符子串与0~n的数组匹配
    j指向[0],i指向[1]
        j字母==i字母
            i的数组值+1
            i右移,j右移
        j字母!=i字母
            j退回[0]位置,重新检查
            



问题出在while循环中,
请问各位能否帮我看下错在哪里,谢谢啦


小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-4-25 07:59:14 From FishC Mobile | 显示全部楼层
这是写next数组?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-4-25 10:56:07 | 显示全部楼层
你这next数组写的什么跟什么啊,
  1.         while(i<=length)
  2.         {
  3.                     if (substr[j]==substr[i])
  4.                     {
  5.                                 sub_array[i] ++;
  6.                                 i++;
  7.                                 j++;
  8.                     }
  9.                     else
  10.                     {
  11.                                 j = 0;
  12.                     }
  13.         }
复制代码

自己读一下,substr[0]!=substr[1]之后不直接死循环了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-4-25 15:33:29 | 显示全部楼层
Croper 发表于 2019-4-25 10:56
你这next数组写的什么跟什么啊,
自己读一下,substr[0]!=substr[1]之后不直接死循环了

谢谢谢谢啦
还没看next数组怎么写hh
了解kmp大概思路之后想自己先试一下,再对比
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-1 10:51

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表