20210922下午
这是考试给出的截图:
这是原题下面的描述
怎么回事呢?
T1 | T2 | T3 | T4 | |
---|---|---|---|---|
预测 | 100 | 100 | 100 | 100 |
一测 | 36 | 10 | 100 | 100 |
T1:
经典,并查集即可。
T2:
A
C
AC
AC自动机应用基础,本题从反向思考,用全部可能减去不含任何单词的语句。那么和不要62几乎没有区别,那么将AC自动机建出来,将
E
n
d
End
End标记下传,然后直接在
t
r
i
e
trie
trie树上跑
d
p
dp
dp就行,考场
f
a
i
l
fail
fail求错了还没下传,写
A
C
AC
AC自动机还没人家写暴力分高。。。
转移:
int dp()
{
f[0][0]=1;int u,v,x=1,y=0,res=0;
for(int i=1;i<=m;i++)
{
x=i&1;y=x^1;
memset(f[x],0,sizeof(f[x]));
for(int j=0;j<=tot;j++)
{
if(End[j]) continue;
for(int k=0;k<26;k++)
{
v=trie[j][k];
if(End[v]) continue;
f[x][v]=(f[x][v]+f[y][j])%mod;
}
}
}
for(int i=0;i<=tot;i++) res+=f[x][i],res%=mod;
return res;
}
T3:
可以转换为
R
M
Q
RMQ
RMQ问题,占一个时间段就是将区间加一,所求即使区间最大值,线段树维护即可。
T4:
类似合并果子,显然从小往大合并是最优的,但由于可能不能每次都能合到
m
m
m堆,简单验证可知先少合一点让之后每次都合
m
m
m堆是最优的,算一下应先合几堆就行。
总结:
A
C
AC
AC自动机没写对太可惜了。