嘟嘟嘟 现在看到字符串就想到SAM,所以很担心kmp啥的会不会忘了-- 这题感觉挺暴力的:首先当然要把\(s\)建成SAM,然后令\(dp[i][j]\)表示到第\(i\)组时,SAM上节点\(j\)能匹配的字符串个数. 转移的时候暴力枚举起点节点\(p\),然后每一次都把当前字符串放上去跑,如果在SAM上存在的话,令结束节点为\(x\),则有\(dp[i][x] += dp[i - 1][p]\). 那么最后的答案就是\(\sum _ {i = 1} ^ {cnt} dp[m][i] * si…