鱼C论坛

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

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

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

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

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

x
void build_array(char* substr, int length)
{
        
        int* sub_array = (int*)malloc((length+1)*sizeof(int));
        for(int a=0; a<=length+1;a++)
        {
                    sub_array[a] = 0;
        }
        int i = 1;
        int j = 0;
        while(i<=length)
        {
                    if (substr[j]==substr[i])
                    {
                                sub_array[i] ++;
                                i++;
                                j++;
                    }
                    else
                    {
                                j = 0;
                    }
        }

        //test the sub_array
        printf("\nThe sub_array so far is :\n");
        for(int k = 0; k<=length; k++)
        {
                    printf("%d ", sub_array[k]);
        }
        printf("\n");
        
}
思路如下:

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



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


想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-4-25 07:59:14 From FishC Mobile | 显示全部楼层
这是写next数组?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-4-25 10:56:07 | 显示全部楼层
你这next数组写的什么跟什么啊,
        while(i<=length)
        {
                    if (substr[j]==substr[i])
                    {
                                sub_array[i] ++;
                                i++;
                                j++;
                    }
                    else
                    {
                                j = 0;
                    }
        }
自己读一下,substr[0]!=substr[1]之后不直接死循环了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

谢谢谢谢啦
还没看next数组怎么写hh
了解kmp大概思路之后想自己先试一下,再对比
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-10-3 17:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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