A. ZYB建围墙

手玩发现这个东西好像有一点规律。

考虑在最优的方案下,每增加一个点对答案的贡献$0/1$,然后随便写写就好了。

 

 

 

B. ZYB和售货机

把$x$向$x$能偷的节点建边。

发现这个东西一定会形成森林,

其中一些树为基环树,其余为普通形态的树。

对于普通形态的树,显然可以赚到其中所有能赚的钱。

但基环树对应着不能从环上一个节点偷另一个节点。

维护偷每个点的最小方案和次小方案,然后枚举环上节点就好了。

 

 

 

C. ZYB玩字符串

因为最终插入了一个字符串$p$,字符串$p$一定可以表示为$s$的一个子串。

所以可以枚举$s$的字串。

贪心地直接匹配后删掉的做法是错误的,可以被很简单的数据卡掉。

然后发现这个东西好像有点像括号匹配,然而字符可以多次出现,于是无从下手。

正解用了一个很优秀的$dp$。

设$dp_{l,r}$表示区间$[l,r]$能否被若干个字符串$p$拼凑出来。

如果$|p|$不被$r-l+1$整除,那么还表示最后能否又拼出$p$的一段前缀。

这个$dp$设计的优秀之处在于当区间长度确定,拓展出现的单个字符对应$p$中位置也是确定的。

分两种情况转移:

由一个字符拓展,对应着最后拼出来的一段的一个。

由若干个$p$拓展,这个过程通过记忆化递归处理。