题目链接

题目

题目描述

输入两个字符串A和B,合并成一个串C,属于A和B的字符在C中顺序保持不变。如"abc"和"xyz"可以被组合成"axbycz"或"abxcyz"等。

我们定义字符串的价值为其最长回文子串的长度(回文串表示从正反两边看完全一致的字符串,如"aba"和"xyyx")。

需要求出所有可能的C中价值最大的字符串,输出这个最大价值即可

输入描述

第一行一个整数T(T ≤ 50)。

接下来2T行,每两行两个字符串分别代表A,B(|A|,|B| ≤ 50),A,B的字符集为全体小写字母。

输出描述

对于每组数据输出一行一个整数表示价值最大的C的价值。

示例1

输入

2
aa
bb
a
aaaabcaa

输出

4
5

题解

知识点:区间dp。

一个字符串的最长回文子串需要一个区间dp即可,而且因为是串,那形成的回文串一定是整个区间,因此比起子序列记录长度,子串只需要记录区间可不可行即可。这道题是两个字符串,考虑二重区间dp。

设 \(dp[i][j][u][v]\) 表示为\(s_1\) 的区间 \([i,j]\) 和 \(s_2\) 的区间 \([u,v]\) 是否能组成回文子串。有转移方程:

\[dp[i][j][u][v] |{=}
\left \{
\begin{array}{l}
dp[i+1][j-1][u][v] &,l_1 \geq 2 且 s_1[i] = s_1[j]\\
dp[i+1][j][u][v-1] &,l_1 \geq 1 且 l_2 \geq 1且s_1[i] = s_2[v]\\
dp[i][j-1][u+1][v] &,l_1 \geq 1 且 l_2 \geq 1且s_2[u] = s_1[j]\\
dp[i][j][u+1][v-1] &,l_2 \geq 1 且 s_2[u] = s_2[v]\\
\end{array}
\right.
\]

因为合并子序列后相对位置不变,端点一定还是端点,枚举可能出现的新端点即可,左右端点 \([left,right]\) 分别可以出现在 \([s_1,s_1],[s_1,s_2],[s_2,s_1],[s_2,s_2]\) 。

时间复杂度 \(O(n^2m^2)\)

空间复杂度 \(O(n^2m^2)\)

代码

#include <bits/stdc++.h>
#define ll long long using namespace std; bool dp[52][52][52][52];
char s1[52], s2[52]; bool solve() {
memset(dp, 0, sizeof(dp));
cin >> s1 + 1 >> s2 + 1;
int n = strlen(s1 + 1);
int m = strlen(s2 + 1);
int ans = 0;
for (int l1 = 0;l1 <= n;l1++) {
for (int l2 = 0;l2 <= m;l2++) {
for (int i = 1, j = l1;j <= n;i++, j++) {
for (int u = 1, v = l2;v <= m;u++, v++) {
if (l1 + l2 <= 1) dp[i][j][u][v] = 1;///(0,0),(0,1),(1,0)的情况都是回文,
else {
if (l1 >= 2 && s1[i] == s1[j]) dp[i][j][u][v] |= dp[i + 1][j - 1][u][v];
if (l1 >= 1 && l2 >= 1 && s1[i] == s2[v]) dp[i][j][u][v] |= dp[i + 1][j][u][v - 1];
if (l1 >= 1 && l2 >= 1 && s2[u] == s1[j]) dp[i][j][u][v] |= dp[i][j - 1][u + 1][v];
if (l2 >= 2 && s2[u] == s2[v]) dp[i][j][u][v] |= dp[i][j][u + 1][v - 1];
}
if (dp[i][j][u][v]) ans = max(ans, l1 + l2);
}
}
}
}
cout << ans << '\n';
return true;
} int main() {
std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
int t = 1;
cin >> t;
while (t--) {
if (!solve()) cout << -1 << '\n';
}
return 0;
}

NC13230 合并回文子串的更多相关文章

  1. 合并回文子串(区间dp)

    链接:https://ac.nowcoder.com/acm/problem/13230来源:牛客网 题目描述 输入两个字符串A和B,合并成一个串C,属于A和B的字符在C中顺序保持不变.如" ...

  2. nowcoder 合并回文子串

    链接:https://www.nowcoder.com/acm/contest/6/C来源:牛客网题目输入两个字符串A和B,合并成一个串C,属于A和B的字符在C中顺序保持不变.如"abc&q ...

  3. 美团2017年CodeM大赛-初赛A轮 C合并回文子串

    区间dp一直写的是递归版本的, 竟然超时了, 学了一下非递归的写法. #include <iostream> #include <sstream> #include <a ...

  4. Manacher's algorithm: 最长回文子串算法

    Manacher 算法是时间.空间复杂度都为 O(n) 的解决 Longest palindromic substring(最长回文子串)的算法.回文串是中心对称的串,比如 'abcba'.'abcc ...

  5. 后缀数组 - 求最长回文子串 + 模板题 --- ural 1297

    1297. Palindrome Time Limit: 1.0 secondMemory Limit: 16 MB The “U.S. Robots” HQ has just received a ...

  6. [leetcode]5. Longest Palindromic Substring最长回文子串

    Given a string s, find the longest palindromic substring in s. You may assume that the maximum lengt ...

  7. LeetCode[5] 最长的回文子串

    题目描述 Given a string S, find the longest palindromic substring in S. You may assume that the maximum ...

  8. 最长回文子串-LeetCode 5 Longest Palindromic Substring

    题目描述 Given a string S, find the longest palindromic substring in S. You may assume that the maximum ...

  9. 最长回文子串(Longest Palindromic Substring)

    这算是一道经典的题目了,最长回文子串问题是在一个字符串中求得满足回文子串条件的最长的那一个.常见的解题方法有三种: (1)暴力枚举法,以每个元素为中心同时向左和向右出发,复杂度O(n^2): (2)动 ...

  10. lintcode最长回文子串(Manacher算法)

    题目来自lintcode, 链接:http://www.lintcode.com/zh-cn/problem/longest-palindromic-substring/ 最长回文子串 给出一个字符串 ...

随机推荐

  1. [转帖]深入JVM - Code Cache内存池

    深入JVM - Code Cache内存池 1. 本文内容 本文简要介绍JVM的 Code Cache(本地代码缓存池). 2. Code Cache 简要介绍 简单来说,JVM会将字节码编译为本地机 ...

  2. [转帖]tidb RESTORE

    https://docs.pingcap.com/zh/tidb/v4.0/sql-statement-restore RESTORE 语句用于执行分布式恢复,把 BACKUP 语句生成的备份文件恢复 ...

  3. [转帖]《Linux性能优化实战》笔记(24)—— 动态追踪 DTrace

    使用 perf 对系统内核线程进行分析时,内核线程依然还在正常运行中,所以这种方法也被称为动态追踪技术.动态追踪技术通过探针机制来采集内核或者应用程序的运行信息,从而可以不用修改内核和应用程序的代码就 ...

  4. ebpf的简单学习

    ebpf的简单学习-万事开头难 前言 bpf 值得是巴克利包过滤器 他的核心思想是在内核态增加一个可编程的虚拟机. 可以在用户态定义很多规则, 然后直接在内核态进行过滤和使用. 他的效率极高. 因为避 ...

  5. [转帖]CPU计算性能speccpu2006的测试方法及工具下载

    https://www.yii666.com/blog/335517.html CPU计算性能speccpu2006的测试方法及工具下载 简介 测试原理 目录结构 测试方法 基准测试项解析 测试结果 ...

  6. Oracle 设置白名单过滤

    最近有一个需求  要求开发人员不能随便连接测试的数据库 又不想太过复杂,部分人还得进行连结. 查了下往上是有方案的: 就是 TCP_VALIDNODE_CHECKING 参数 解决方法和说明如下 来源 ...

  7. 一个Redis dump文件的简要分析过程

    摘要 遇到一个老大难的问题. 让帮忙分析一下一个Redis的dump文件. 虽然之前写过了rdb和rdr的文档 但是感觉大家都喜欢拿来主义. 没办法. 今天继续进行深入一点的分析. 原理其实还是基于r ...

  8. vCenter 6.7 使用Grafana监控失败的处理

    背景 国庆处理的vCenter监控. 老的vCenter6.0的平台很正常. 但是新的vCenter 6.7 就经常出现断连的情况. 花费了快一个多小时才搞定, 这里记录一下. 问题现象 vCente ...

  9. 截止2021年linux发行版

  10. Linux 界面能够出现ip地址提示的方法

    cat <<EOF >/etc/profile.d/ip.sh if [[ `tty | grep "pts"` ]]; then export PS1='['& ...