next数组的求解方法是:
第0位的next值为-1,第1位的next值为0,后面求解每一位的next值时,根据前一位进行比较。
首先将前一位与其next值对应的内容进行比较,如果相等,则该位的next值就是前一位的next值加上1;如果不等,向前继续寻找next值对应的内容来与前一位进行比较,直到找到某个位上内容的next值对应的内容与前一位相等为止,则这个位对应的值加上1即为需求的next值;如果找到第一位都没有找到与前一位相等的内容,那么需求的位上的next值即为0。
如果数组的下标是从1 开始的 那么Next数组默认第0位和第1位 是0 和 1
举例解释上边一段话的意思
假设求串′ababaaababaa′的next数组
| 模式串 | a | b | a | b | a | a | a | b | a | b | a | a |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 下标 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
1、前两位:next数组前两位一定是-1,0 即前两位ab对应的next数组为-1 0,则:
| 模式串 | a | b | a | b | a | a | a | b | a | b | a | a |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 下标 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| next数组 | -1 | 0 |
2、接下来看第2位,按照next数组求解方法。第2位a的前一位为第1位的b,b的next值为0对应内容为a,b与a不同,向前继续寻找next值对应的内容来与前一位进行比较。因为找到第0位都没有找到与前一位相等的内容,所以第2位a的next值为0,则:
| 模式串 | a | b | a | b | a | a | a | b | a | b | a | a |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 下标 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| next数组 | -1 | 0 | 0 |
3、接下来看第3位b,b的前一位a的next=0对应内容为a,相同,所以该位b的next值就是前一位a的next+1,即为1
| 模式串 | a | b | a | b | a | a | a | b | a | b | a | a |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 下标 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| next数组 | -1 | 0 | 0 | 1 |
4、接下来看第4位a,a的前一位b的next=1对应内容为b,相等,所以该位a的next值就是前一位b的next+1,即为2
| 模式串 | a | b | a | b | a | a | a | b | a | b | a | a |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 下标 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| next数组 | -1 | 0 | 0 | 1 | 2 |
5、接下来看第5位a,a的前一位a的next=2对应内容为a,相等,所以该位a的next值就是前一位a的next+1,即为3
| 模式串 | a | b | a | b | a | a | a | b | a | b | a | a |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 下标 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| next数组 | -1 | 0 | 0 | 1 | 2 | 3 |
6、接下来看第6位a,a的前一位a的next=3对应内容为b,不相等,向前继续寻找next值对应的内容来与前一位进行比较,b的next=1对应的内容为b,依旧不相等,继续向前寻找,第1位b的next=0对应内容为a,相等。因为是在第1位b处实现的相等,所以第6位a的next值为第1位b的next+1,即为1
| 模式串 | a | b | a | b | a | a | a | b | a | b | a | a |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 下标 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| next数组 | -1 | 0 | 0 | 1 | 2 | 3 | 1 |
7、接下来看第7位,同样道理,得出b的next值为1
| 模式串 | a | b | a | b | a | a | a | b | a | b | a | a |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 下标 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| next数组 | -1 | 0 | 0 | 1 | 2 | 3 | 1 | 1 |
8、接下来看第8位,前一位b的next值1对应内容为b,相等,所以此处next值为2
| 模式串 | a | b | a | b | a | a | a | b | a | b | a | a |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 下标 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| next数组 | -1 | 0 | 0 | 1 | 2 | 3 | 1 | 1 | 2 |
9、第9位同理可得,为3
| 模式串 | a | b | a | b | a | a | a | b | a | b | a | a |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 下标 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| next数组 | -1 | 0 | 0 | 1 | 2 | 3 | 1 | 1 | 2 | 3 |
10、第10位a的前一位b的next值3对应内容为b,相等,所以此处next值为4
| 模式串 | a | b | a | b | a | a | a | b | a | b | a | a |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 下标 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| next数组 | -1 | 0 | 0 | 1 | 2 | 3 | 1 | 1 | 2 | 3 | 4 |
11、最后,第11位同理可以得到next值位5
| 模式串 | a | b | a | b | a | a | a | b | a | b | a | a |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 下标 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| next数组 | -1 | 0 | 0 | 1 | 2 | 3 | 1 | 1 | 2 | 3 | 4 | 5 |
综上,串′ababaaababaa′的next数组为-1 0 0 1 2 3 1 1 2 3 4 5
如果数组下标是从1开始 next数组从0 开始 结果就是上边的每个+1 0 1 1 2 3 4 2 2 3 4 5 6
本文详细介绍了如何计算模式串的next数组,通过逐步示例解释了从头开始寻找匹配内容的过程,展示了如何根据前一位的next值确定当前位的next值,从而构建完整的next数组。
1619

被折叠的 条评论
为什么被折叠?



