2018/7/28 训练日记

今天牛客的比赛,感觉有点疲惫

一道签到题让我想复杂了,一个劲的找错,队友开了另外的题,我自己冲着签到题较劲较了好久,最后在队友的帮助下A了,

一开始的思路想复杂了,之后又钻了牛角尖,导致出题太慢

然后队友开了个贪心,我们几个想构造题,这个构造题蛮灵活的,实验室的人都用不同的构造方法写出来了,挺神奇的一个题

非常有意思。贪心题明天也打算补一下。

再就是2015年的多校的看题

有一个后缀自动机的题,题目是这样描述的:

给定两个长度不超过a,b,x为a的连续子串,b为y的连续子串(x和y均可以是空串);

问x+y形成的不同串的个数

正解将题目转化了:

扫描二维码关注公众号,回复: 2577202 查看本文章

直接在计算有不同子串时,就不去计算重复的 <=>

对于一个可能出现x后缀和y前缀相同而重复计算的情况,就全部加入x而y变为去掉前缀的部分;

即找到x最后一个字符ch,使得在x后能加的字符串不以ch开头,这样就避免了重复的情况。

对第二个串建SAM求出第二个串的以每个字符开头的不同子串的数目

再对第一个串建SAM,遍历自动机如果某个节点后面没有某个字符则答案加上这个节点的出现次数

乘上以这个字符为开头的在第二个串中的不同子串的数目

明天怕是要疯狂补题解了

猜你喜欢

转载自blog.csdn.net/qq_37748451/article/details/81265724