28. Find the Index of the First Occurrence in a String
这道题用KMP算法
文本串: a a b a a b a a f
模式串: a a b a a f
前缀: 包含首字母,不包含尾字母的所有子串;
后缀: 包含尾字母,不包含首字母的所有子串;
当第一次匹配的时候发现模式串的f与文本串的b不匹配,但是知道模式串中f之前的数据都与文本串一样。在这样的前提下下一次匹配的时候文本串直接从f当前的这个下标开始往后匹配,模式串由于“最长相等前后缀”的存在直接从b开始往后匹配,从而降低时间复杂度。
next数组放的就是前缀表;具体