先对原串建立后缀自动机。考虑每个询问。询问的子串相当于考虑它的n个循环串,因此我们把询问串连接在询问串,那么这个新串的长度为n的子串就是所要求的串。把新串放在后缀自动机上面跑,同时记录现在新串匹配的最长后缀len。如果len>=当前串长度n,那么我们就沿着fa指针跳到满足len>=n且长度最小的节点。那么原点到这个节点必然有一条路径的字符串是当前匹配的长度为n的后缀。这个节点的right集合大小就是所求的答案。但是可能会出现重复,每个节点记录一个vis值就可以了。。累加答案即可。。。
【【后缀自动机】 CodeForces 235C Cyclical Quest】
#include
#include
#include
#include
推荐阅读