位序
1
2
3
4
5
6
7
8
模式串
a b a a b c a c
next值
0
1 1
2 2
3 1
2
nextval值 0 1 0 2 1 3 0 2
next数组的求解方法是:
1.第一位的next值为0
2.第二位的next值为1
后面求解每一位的next值时,根据前一位进行比较
3.第三位的next值:第二位的模式串为b ,对应的next值为1;将第二位的模式串b与第一位的模式串a进行比较,不相等;则第三位的next值为1
4.第四位的next值:第三位的模式串为a ,对应的next值为1;将第三位的模式串a与第一位的模式串a进行比较,相同,则第四位的next值得为2
5.第五位的next值:第四位的模式串为a,对应的next值为2;将第四位的模式串a与第二位的模式串b进行比较,不相等;第二位的b对应的next值为1,则将第四位的模式串a与第一位的模式串a进行比较,相同,则第五位的next的值为2
6.第六位的next值:第五位的模式串为b,对应的next值为2;将第五位的模式串b与第二位的模式中b进行比较,相同,则第六位的next值为3
7.第七位的next值:第六位的模式串为c,对应的next值为3;将第六位的模式串c与第三位的模式串a进行比较,不相等;第三位的a对应的next值为1,则将第六位的模式串c与第一位的模式串a进行比较,不相同,则第七位的next值为1
8.第八位的next值:第七位的模式串为a,对应的next值为1;将第七位的模式串a与第一位的模式串a进行比较,相同,则第八位的next值为2
nextval数组的求解方法是:
1.第一位的nextval值必定为0,第二位如果与第一位相同则为0,如果不同则为1;
2.第三位的next值为1,则将第三位与第一位进行比较,相同,则第三位的nextval值为0;
3.第四位的next值为2,则将第四位和第二位进行比较,不同,则第四位的next值为其next值,为2;
4.第五位的next值为2,则将第五位和第二位进行比较,相同,则第二位的next值为1,则进行将第二位与第一位进行比较,不同,则第五位的nextval值为第二位的next值,为1;
5.第六位的next值为3,则将第六位与第三位进行比较,不同,则第六位的nextval值为其next值,为3;
6.第七位的next值为1,则将第七位与第一位进行比较,相同,则第七位的nextval值为0;
7.第八位的next值为2,则将第八位与第二位进行比较,不同,则第八位的nextval值为其next值,为2;