poj2955(括号匹配问题)
来源:互联网 发布:仿 购物商城 app 源码 编辑:程序博客网 时间:2024/06/05 20:48
题意:给你一串()[]括号,要你求出这串括号的最大匹配个数,如'('与')'匹配,为2个,'['与']'匹配,为2个,其他不能匹配.......
思路:dp[i][j]代表从区间i到区间j所匹配的括号的最大个数,首先,假设不匹配,那么dp[i][j]=dp[i+1][j];然后查找i+1~~j有木有与第i个括号匹配的
有的话,dp[i][j]=max(dp[i][j],dp[i+1][k-1]+dp[k][j]+2).....
代码:
#include<iostream>#include<algorithm>#include<cstdio>#include<cstring>#define INF 0x3fffffffusing namespace std;char a[105];int dp[105][105];int main(){ char b[6] = "end"; while(scanf("%s",a) != EOF){ if(!strcmp(b,a))break; int n = strlen(a); memset(dp,0,sizeof(dp)); for(int i = 2; i <= n; i++){ for(int j = 0; j < n; j++){ int theend = j+i-1; dp[j][theend] = dp[j][theend-1]; if(a[theend] == ')'){ for(int k = theend-1; k >= j; k--){ if(a[k] == '(') dp[j][theend] = max(dp[j][theend],dp[j][k-1]+dp[k+1][theend-1]+2); } } if(a[theend] == ']'){ for(int k = theend-1; k >= j; k--){ if(a[k] == '[') dp[j][theend] = max(dp[j][theend],dp[j][k-1]+dp[k+1][theend-1]+2); } } } } cout << dp[0][n-1] << endl; }}
0 0
- poj2955(括号匹配问题)
- poj2955(括号匹配DP)
- POJ2955 Brackets(区间DP,括号匹配)
- poj2955,括号匹配,区间dp
- poj2955 Brackets--最大括号匹配数
- FZU 2030 括号问题 (括号匹配)
- 括号匹配问题(nyoj2)
- 括号匹配问题(一)
- 括号匹配问题(1)
- 括号匹配问题(只考虑小括号)。
- 括号匹配问题(动态规划)
- 排队游戏(括号匹配问题2)
- 【Openjudge】括号匹配问题(递归)
- 详解括号匹配问题(STL stack)
- 括号匹配问题(判断以及添加)
- (C语言)括号匹配问题
- ACM括号匹配问题(java实现)
- Parenthesis(括号平衡串,匹配问题)
- 圆周率问题
- 蜜汁错误
- C--字符串操作函数
- 栈回溯技术及uClibc的堆实现原理
- get_included_files函数
- poj2955(括号匹配问题)
- Spring 实现动态注册Bean
- 欢迎使用CSDN-markdown编辑器
- SAP推出下一代数字转型平台SAP HANA 2
- 更新订单内多个商品的数量---在存在相同商品id时。
- 从1到n整数中1出现的次数
- 笔记
- DP 数字三角形+找钱问题
- Android中使用Handler造成内存泄露的分析和解决