多校第二场 String Distance(DP)

题意
给两个串A(1…n)和B(1…m),其中n<=1e5,m<=20。多组询问,每一次询问给一组(l,r)值,问至少经过多少次增减操作使得A(l…r)与B(1…m)相同。
思路
难点一:增操作没有必要
考虑最终相等的串,再考虑某一个位置,如果该位置对应的A串和B串字符均是添加进去的,我们可以更优地去除这个位置的字符,从而使答案更优;如果该位置对应的其中一个串的字符是添加进去的,另外一个没有操作,那么我们可以把这个添加操作改为删除操作。因此,增操作均可以由删操作替代
难点二:ans = |r- l + 1| + |m| - 2lcs(串1,串2);
lcs表示两个串的最长公共子序列(注意是子序列不是子串
了解lcs后,这个结论自然就得出来了
难点三:如果处理多组询问?
注意到m<=20,所以可以支持 n 2 n^2 n2操作
我们不妨令
f [ i ] [ j ] 表 示 B [ 1... i ] 与 A [ l . . . r ] 最 长 公 共 子 序 列 长 度 为 j 的 在 A 中 的 最 小 位 置 a n s = ∣ r − l + 1 ∣ + ∣ m ∣ − 2 ∗ j ( 其 中 满 足 f [ m ] [ j ] < = r 的 最 大 j ) f[i][j]表示B[1...i]与A[l...r]最长公共子序列长度为j的在A中的\\最小位置\\ans=|r-l+1|+|m|-2*j(其中满足f[m][j]<=r的最大j) f[i][j]B[1...i]A[l...r]jAans=rl+1+m2j(f[m][j]<=rj)
考虑DP转移式子
对 于 f [ i − 1 ] [ j ] ( j 属 于 0 − m ) 已 经 确 定 的 状 态 如 何 更 新 f [ i ] [ . . . ] 很 简 单 , 影 响 f [ i ] [ . . . ] 状 态 的 只 有 B [ i ] 的 值 , 所 以 我 们 只 需 要 确 定 B [ i ] 会 不 会 更 新 f [ i ] [ . . . ] 即 可 对于f[i-1][j](j属于0-m)已经确定的状态如何更新f[i][...]\\很简单,影响f[i][...]状态的只有B[i]的值,所以我们只需要\\确定B[i]会不会更新f[i][...]即可 f[i1][j](j0m)f[i][...]f[i][...]B[i]B[i]f[i][...]
f [ i ] [ j ] = m i n ( f [ i ] [ j ] , f [ i − 1 ] [ j ] ) − − 自 然 传 递 f[i][j]=min(f[i][j], f[i-1][j])--自然传递 f[i][j]=min(f[i][j],f[i1][j])

i f ( f [ i − 1 ] [ j − 1 ] . . . n 中 存 在 B [ i ] 且 最 小 位 置 p o s 小 于 等 于 r ) = > f [ i ] [ j ] = m i n ( f [ i ] [ j ] , p o s ) − − B [ i ] 影 响 if(f[i - 1][j - 1]...n中存在B[i]且最小位置pos小于等于r)\\=>f[i][j]=min(f[i][j], pos)--B[i]影响 if(f[i1][j1]...nB[i]posr)=>f[i][j]=min(f[i][j],pos)B[i]

难点四:如何在A[1…n]中确定B[1…m]中存在B[i]且最小位置小于等于r
其实这个题解提供的方法比较不错;
c [ i ] [ j ] 表 示 A [ i . . . n ] 中 字 符 j 的 最 小 下 标 i f ( A [ i ] = = j ) , c [ i ] [ j ] = i ; e l s e , c [ i ] [ j ] = c [ i + 1 ] [ j ] c[i][j]表示A[i...n]中字符j的最小下标\\if(A[i]==j),c[i][j]=i;else,c[i][j] = c[i + 1][j] c[i][j]A[i...n]jif(A[i]==j),c[i][j]=i;else,c[i][j]=c[i+1][j]

AC代码

你可能感兴趣的:(2020年暑假集训)