https://jzoj.net/senior/#main/show/3427
想法:
先把A串中所有连成一块的不含“”的子串提取出来,把b串copy一份,求f[i][j]表示b串第i位到i+len位是否和a串的第j个子串匹配(hash或暴力),然后在求一个next[i][j]表示i及后面中第一个位置及后面可以和第j个子串匹配的位置,(初始值如果没有的话设较大的数,(f[i][j]=1)next[i][j]=i(other)next[i][j]=next[i+1][j]),然后枚举一个起点,然后不断利用next[i][j]往后跳,如果跳过了(next的初始值),不合法,如果终点-起点》m不合法,如果a串的第一个和最后一个不为‘’,还要判断一下能否匹配
JZOJ3427. 【NOIP2013模拟】归途与征程 (2017.8B组)
最新推荐文章于 2019-08-20 10:29:44 发布