摘要: 依稀记得,$NOIP$之前的我是如此的弱小.... 完全不会$KMP$的写法,只会暴力$hash$.... 大体思路为把一个串的哈希值拆成$26$个字母的位权 即$hash(S) = \sum\limits_{a} a * \sum w^i * [s[i] == a]$ 通过记录每个字母第一次出现的 阅读全文
posted @ 2018-11-12 22:06 remoon 阅读(295) 评论(0) 推荐(0) 编辑
摘要: 可以非常轻易的将题意转化为有多少子串满足排名相同 注意到$KMP$算法只会在当前字符串的某尾添加和删除字符 因此,如果添加和删除后面的字符对于前面的字符没有影响时,我们可以用$KMP$来模糊匹配 对于本题而言,在末尾插入一个字符时,如果$S$串和$T$串中这两个字符的排名一样,那么它们对前面的影响也 阅读全文
posted @ 2018-11-12 21:38 remoon 阅读(357) 评论(0) 推荐(0) 编辑
摘要: 明显的,有$next[i] = i - pre[i]$ 根据$next[i]$构造比根据$pre[i]$简单 如果$next[i] \neq 0$,那么我们可以直接取前面的结果 否则,我们可以暴力的寻找$next[i - 1], next[next[i - 1]] ...$后一位中最小没有出现过的字 阅读全文
posted @ 2018-11-12 20:28 remoon 阅读(151) 评论(0) 推荐(0) 编辑