【cf1272】F. Two Bracket Sequences
题意:
给出\(s,t\)两个合法括号序列,现在找到一个长度最小的合法的序列\(p\),使得\(s,t\)都为其子序列。
思路:
- 考虑\(dp:dp[i][j][d]\)表示第一个串在\(i\),第二个串在\(j\),答案串左括号和右括号之差为\(d\)时的最短长度。
- 那么转移时枚举下一位转移即可。
- 还需要考虑一点细节:若当前\(d=0\),但是下一位为)时,我们需要先\(dp[i][j][0]\)向\(dp[i][j][1]\)转移,即在答案串中添加一个(来匹配。
- 最后的答案即为\(min\{dp[n][m][d]+d\}\),若\(d>0\)时,我们还需要在答案串后面添加\(d\)个)来使其合法。
- 输出路径时转移时记录一下前驱,然后根据\(d\)来找到当前应为哪个括号。
代码如下:
/*
* Author: heyuhhh
* Created Time: 2019/12/13 11:40:50
*/
#include <iostream>
#include <algorithm>
#include <cstring>
#include <vector>
#include <cmath>
#include <set>
#include <map>
#include <queue>
#include <iomanip>
#define MP make_pair
#define fi first
#define se second
#define sz(x) (int)(x).size()
#define all(x) (x).begin(), (x).end()
#define INF 0x3f3f3f3f
#define Local
#ifdef Local
#define dbg(args...) do { cout << #args << " -> "; err(args); } while (0)
void err() { std::cout << '\n'; }
template<typename T, typename...Args>
void err(T a, Args...args) { std::cout << a << ' '; err(args...); }
#else
#define dbg(...)
#endif
void pt() {std::cout << '\n'; }
template<typename T, typename...Args>
void pt(T a, Args...args) {std::cout << a << ' '; pt(args...); }
using namespace std;
typedef long long ll;
typedef pair<int, int> pii;
//head
const int N = 200 + 5;
struct node {
int i, j, k;
};
node pre[N][N][N << 1];
int dp[N][N][N << 1];
int n, m;
char s[N], t[N];
void run(){
cin >> (s + 1) >> (t + 1);
n = strlen(s + 1);
m = strlen(t + 1);
memset(dp, INF, sizeof(dp));
dp[0][0][0] = 0;
for(int i = 0; i <= n; i++) {
for(int j = 0; j <= m; j++) {
if(i == n && j == m) break;
for(int k = 0; k < N; k++) if(dp[i][j][k] != INF) {
if(s[i + 1] == t[j + 1]) {
if(s[i + 1] == ')') {
if(k == 0) {
if(dp[i][j][k + 1] > dp[i][j][k] + 1) {
dp[i][j][k + 1] = dp[i][j][k] + 1;
pre[i][j][k + 1] = node {i, j, k};
}
}
if(dp[i + 1][j + 1][k - 1] > dp[i][j][k] + 1) {
dp[i + 1][j + 1][k - 1] = dp[i][j][k] + 1;
pre[i + 1][j + 1][k - 1] = node {i, j, k};
}
} else if(s[i + 1] == '(') {
if(dp[i + 1][j + 1][k + 1] > dp[i][j][k] + 1) {
dp[i + 1][j + 1][k + 1] = dp[i][j][k] + 1;
pre[i + 1][j + 1][k + 1] = node {i, j, k};
}
}
} else {
if(s[i + 1] == ')') {
if(k == 0) {
if(dp[i][j][k + 1] > dp[i][j][k] + 1) {
dp[i][j][k + 1] = dp[i][j][k] + 1;
pre[i][j][k + 1] = node {i, j, k};
}
}
if(dp[i + 1][j][k - 1] > dp[i][j][k] + 1) {
dp[i + 1][j][k - 1] = dp[i][j][k] + 1;
pre[i + 1][j][k - 1] = node {i, j, k};
}
} else if(s[i + 1] == '(') {
if(dp[i + 1][j][k + 1] > dp[i][j][k] + 1) {
dp[i + 1][j][k + 1] = dp[i][j][k] + 1;
pre[i + 1][j][k + 1] = node {i, j, k};
}
}
if(t[j + 1] == ')') {
if(k == 0) {
if(dp[i][j][k + 1] > dp[i][j][k] + 1) {
dp[i][j][k + 1] = dp[i][j][k] + 1;
pre[i][j][k + 1] = node {i, j, k};
}
}
if(dp[i][j + 1][k - 1] > dp[i][j][k] + 1) {
dp[i][j + 1][k - 1] = dp[i][j][k] + 1;
pre[i][j + 1][k - 1] = node {i, j, k};
}
} else if(t[j + 1] == '(') {
if(dp[i][j + 1][k + 1] > dp[i][j][k] + 1) {
dp[i][j + 1][k + 1] = dp[i][j][k] + 1;
pre[i][j + 1][k + 1] = node {i, j, k};
}
}
}
}
}
}
int Min = INF;
node ans;
for(int i = 0; i < N; i++) {
if(dp[n][m][i] + i < Min) {
Min = dp[n][m][i] + i;
ans = node {n, m, i};
}
}
//for(int i = 400; i < 410; i++) {
//cout << dp[1][3][i] << '\n';
//}
string res = "";
node now = ans, last;
while(1) {
last = pre[now.i][now.j][now.k];
//dbg(now.i, now.j, now.k, dp[now.i][now.j][now.k]);
if(last.k > now.k) res += ")";
else res += "(";
now = last;
if(now.i == 0 && now.j == 0 && now.k == 0) break;
}
reverse(res.begin(), res.end());
for(int i = 0; i < ans.k; i++) res += ")";
cout << res << '\n';;
}
int main() {
ios::sync_with_stdio(false);
cin.tie(0); cout.tie(0);
cout << fixed << setprecision(20);
run();
return 0;
}
【cf1272】F. Two Bracket Sequences的更多相关文章
- 【AtCoder】ARC092 D - Two Sequences
[题目]AtCoder Regular Contest 092 D - Two Sequences [题意]给定n个数的数组A和数组B,求所有A[i]+B[j]的异或和(1<=i,j<=n ...
- 【python】f.write()写入中文出错解决办法
一个出错的例子 #coding:utf-8 s = u'中文' f = open("test.txt","w") f.write(s) f.close() 原因 ...
- 【原创】leetCodeOj --- Repeated DNA Sequences 解题报告
原题地址: https://oj.leetcode.com/problems/repeated-dna-sequences/ 题目内容: All DNA is composed of a series ...
- 【LeetCode】187. Repeated DNA Sequences
题目: All DNA is composed of a series of nucleotides abbreviated as A, C, G, and T, for example: " ...
- MT【248】$f(x)=\dfrac{1}{x-1}+\dfrac{1}{x-b}$的性质
探讨函数$f(x)=\dfrac{1}{x-a}+\dfrac{1}{x-b}$其中$a<b$的几个性质 分析:对称性:关于$(\dfrac{a+b}{2},0)$证明提示:$f(x)+f(a+ ...
- 【ARC066】F - Contest with Drinks Hard
题解 我写的斜率维护,放弃了我最擅长的叉积维护,然后发现叉积维护也不会爆long long哦-- 一写斜率维护我的代码就会莫名变长而且难写--行吧 我们看这题 推了推式子,发现这是个斜率的式子,但是斜 ...
- 【HDU4734】F(x) 【数位dp】
题意 先定义了一个函数F(X)=An*2^n-1+An-1*2^n-2+.....+A1*1.其中Ai为X的第i位的值.对于每组数据给出了两个整数A,B.问不超过B的数中有多少的F值是不超过F(A)的 ...
- 【hdu4734】F(x) 数位dp
题目描述 对于一个非负整数 $x=\overline{a_na_{n-1}...a_2a_1}$ ,设 $F(x)=a_n·2^{n-1}+a_{n-1}·2^{n-2}+...+a_2·2^1+ ...
- 【数位dp入门】【HDU4734】F(x)
记录减的状态,表示还要凑多少才能达到当前值. 然后进行枚举即可.注意状态数不能重复. #include<bits/stdc++.h> #define N 10010 using names ...
随机推荐
- 利用Fiddler对Jmeter的请求进行抓包
前言 有时候,为了得到更详细的请求结果,我们可能需要使用Fiddler结合Jmeter来抓包分析,从而更好的辅助测试. 遇到的问题 这里以一个获取学生信息的接口为例进行说明. 当我在Jmeter里按接 ...
- Koa 本地搭建 HTTPS 环境
openssl 首先本地需要安装 openssl,用于生成自签名证书. $ brew install openssl 检查安装: $ openssl version LibreSSL 2.6.5 生成 ...
- C# -- Quartz.Net入门案例
1. 入门案例 using Quartz;using Quartz.Impl; public class PrintTime : IJob { public Task Execute(IJobExec ...
- Java时区问题
Java时区相关 时间格式 UTC是以原子时计时,更加精准,适应现代社会的精确计时.不过一般使用不需要精确到秒时,视为等同.GMT是前世界标准时,UTC是现世界标准时.每年格林尼治天文台会发调时信息, ...
- axios解决跨域问题(vue-cli3.0)
一.什么是跨域 1.跨域 指的是浏览器不能执行其他网站的脚本.它是由浏览器的同源策略造成的,是浏览器对javascript施加的安全限制. 2.同源策略 是指协议,域名,端口都要相同,其中有一个不同都 ...
- Windows相关操作(备忘)
查看服务端口是否能通:telnet 192.168.1.11 8888 查看端口是否被占用 netstat -ano
- Android五大布局详解——LinearLayout(线性布局)
Android五大布局 本篇开始介绍Android的五大布局的知识,一个丰富的界面显示总是要有众多的控件来组成的,那么怎样才能让这些控件能够按你的想法进行摆放,从而自定义你所想要的用户界面呢?这就牵涉 ...
- SLES 12: Database Startup Error with ORA-27300 ORA-27301 ORA-27303 While Starting using Srvctl (Doc ID 2340986.1)
SLES 12: Database Startup Error with ORA-27300 ORA-27301 ORA-27303 While Starting using Srvctl (Doc ...
- August 25th, 2019. Sunday, Week 35th.
It's what you do next that counts, not what happens but what you decide to do about it. 重点不是发生了什么,而是 ...
- 1+x 证书 Web 前端开发中级理论考试(试卷 8 )含答案
1+x 证书 Web 前端开发中级理论考试(试卷 8 ) 官方QQ群 转载请注明来源:妙笔生花个人博客http://blog.zh66.club/index.php/archives/438/ 一.单 ...