Descripion:
给定一个字符串,可以更改其中的
k
k
个字符,要求最大化该字符串与其翻转字符串的长度,求该长度。
Solution:
dpi,j,k
d
p
i
,
j
,
k
表示区间
[i,j]
[
i
,
j
]
修改了
k
k
个字符最长的。很明显如果没有修改最长的
LCS
L
C
S
为最长回文子序列,那么每次考虑两端字符是否匹配或者修改或者不选即可。
#include <bits/stdc++.h>
using namespace std;
int n, k, ans;
char s[305];
int dp[305][305][305];
int dfs(int l, int r, int x) {
if(l >= r) {
return r - l + 1;
}
if(dp[l][r][x] != -1) {
return dp[l][r][x];
}
int ret = max(dfs(l + 1, r, x), dfs(l, r - 1, x));
if(s[l] == s[r]) {
ret = max(ret, dfs(l + 1, r - 1, x) + 2);
} else if(x) {
ret = max(ret, dfs(l + 1, r - 1, x - 1) + 2);
}
return dp[l][r][x] = ret;
}
int main() {
memset(dp, -1, sizeof(dp));
scanf("%s%d", s + 1, &k);
n = strlen(s + 1);
for(int i = 1; i <= n; ++i) {
for(int j = i; j <= n; ++j) {
ans = max(ans, dfs(i, j, k));
}
}
printf("%d\n", ans);
return 0;
}