第二次看kmp,才有点搞懂这个算法(我真是太弱了,就该orz陈老师和龙老师): kmp算法完成的任务是:给定两个字符串O和f,长度分别为n和m,判断f是否在O中出现,如果出现则返回出现的位置.常规方法是遍历a的每一个位置,然后从该位置开始和b进行匹配,但是这种方法的复杂度是O(nm).kmp算法通过一个O(m)的预处理,使匹配的复杂度降为O(n+m). kmp算法实际上就是字符串匹配的一个优化而已,因为我们在做普通字符串匹配的时候,是逐字匹配,一旦不一样就重新匹配,但是这样却忽略了一个事实,我们…