UVALive-8078 Bracket Sequence 简单dp
Posted tanglizi
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了UVALive-8078 Bracket Sequence 简单dp相关的知识,希望对你有一定的参考价值。
题目链接:https://cn.vjudge.net/problem/UVALive-8078
题意
括号序列T是这样定义的:
- T是个空的
- T是(T), {T},
- T是两个T组成的,比如()()就是一个T
现在给一个n个字符长的串,问以每个字符为左端点的最长括号序列是多长。
思路
显然对i这个地方可以讨论一下:
如果i是个右括号,答案是0。
如果i是个左括号:
如果以i+1为起点的最长串后边的字符与左括号匹配,答案是加上这个字符后边的最长串。
如果不匹配,答案是0。
细节上注意不要越界即可,边界是dp[strlen]=0
提交过程
AC |
代码
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int maxn=2e5;
char str[maxn];
int sign[300], ans[maxn];
int main(void){
int T, kase=0;
sign[‘(‘]=1;
sign[‘{‘]=2;
sign[‘[‘]=3;
sign[‘<‘]=4;
sign[‘)‘]=-1;
sign[‘}‘]=-2;
sign[‘]‘]=-3;
sign[‘>‘]=-4;
scanf("%d", &T);
while (T--){
scanf("%s", str);
memset(ans, 0, sizeof(ans));
int len=strlen(str);
for (int i=len; i>=0; i--){
int elem=sign[str[i]];
if (elem<0) ans[i]=0;
else{
if (i+1<len && sign[str[i+1]]==elem*-1) ans[i]=2+ans[i+2];
else if (i+1<len){
int nxt=sign[str[ans[i+1]+i+1]];
// printf("%d %d --
", nxt, elem);
if (nxt==elem*-1) ans[i]=ans[i+1]+2+ans[i+ans[i+1]+2];
else ans[i]=0;
}else if (i+1>=len) ans[i]=0;
}
}
printf("Case %d:
", ++kase);
for (int i=0; i<len; i++)
printf("%d
", ans[i]);
}
return 0;
}
Time | Memory | Length | Lang | Submitted |
---|---|---|---|---|
49ms | None | 1116 | C++ 5.3.0 | 2018-08-24 11:28:32 |
以上是关于UVALive-8078 Bracket Sequence 简单dp的主要内容,如果未能解决你的问题,请参考以下文章
Least Cost Bracket Sequence(贪心)