给定一个模式串,有若干个单词,问是否能用若干个单词组合,组合成模式串
ICPC-2007 Asia regional - Nanjing
题目链接
https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&category=282&page=show_problem&problem=1943
思路:这种有后缀类型的题目一开始还以为是后缀数组,然后仔细想了一下,后缀数组更多的是解决两个大的模式串之间产生的后缀之间的关系,而这个实际上是要把一堆小的零散的单词拼凑成一个大的模式串,所以给用第二种匹配方法.刘老师说这个超棒的
首先给明白一个递推关系,实际上我们可以直接从最后出发,命名一个dp数组,推出状态转移方程即dp[i] = dp[i +len(x)] + dp[i]
认为dp[i]实质上是为组成以i开始到总长度的组成反感,x实际上就是i到总长度这个子串的长度
那么解法就可以出来了
我们将所有出现的单词压入字典树
倒着遍历一遍,因为不限制单词重复使用,所以我们可以将所有适合的方案全部压入对应的后缀之中,然后相应修改匹配模块即可
#include
#include
#include
#include
#include
#include