KMP算法中的next数组可以使用动态规划的思路,用C语言来求next数组的过程可以描述如下:
- 将next数组的第一个元素设置为-1。
- 从第二个元素开始,设置为其前一个元素的next值,也就是next[i] = next[i-1] + 1。
- 如果下标i处的字符和下标next[i-1]处的字符相同,则next[i] = next[i-1] + 1;
- 如果下标i处的字符和下标next[i-1]处的字符不同,则找到下一个最大相同前缀后缀的位置,将next[i]设置为该位置的next值。
- 重复上述步骤,直到数组的最后一个元素。