码迷,mamicode.com
首页 > 其他好文 > 详细

POJ 2955 Brackets(区间DP)题解

时间:2019-01-24 23:07:05      阅读:149      评论:0      收藏:0      [点我收藏+]

标签:scanf   clu   def   using   map   i++   bre   algo   cstring   

题意:问最多有几个括号匹配

思路:用dp[i][j]表示i到j最多匹配,若i和j构成匹配,那么dp[i][j] = dp[i + 1][j - 1] + 2,剩下情况dp[i][j] = max(dp[i][j], dp[i][k] + dp[k + 1][j])

代码:

#include<set>
#include<map>
#include<cmath>
#include<queue>
#include<cstdio>
#include<cstring>
#include<algorithm>
typedef long long ll;
using namespace std;
const int maxn = 100 + 10;
const int MOD = 1e9 + 7;
const int INF = 0x3f3f3f3f;
int dp[maxn][maxn];
char s[maxn];
bool ok(int i, int j){
    if(s[i] == ( && s[j] == )) return true;
    if(s[i] == [ && s[j] == ]) return true;
    return false;
}
int main(){
    while(~scanf("%s", s + 1)){
        if(strcmp(s + 1, "end") == 0) break;
        memset(dp, 0, sizeof(dp));
        int n = strlen(s + 1);
        for(int len = 2; len <= n; len++){
            for(int i = 1; i + len - 1 <= n; i++){
                int j = i + len - 1;
                if(ok(i, j)){
                    dp[i][j] = dp[i + 1][j - 1] + 2;
                }
                for(int k = i; k < j; k++){
                    dp[i][j] = max(dp[i][j], dp[i][k] + dp[k + 1][j]);
                }
            }
        }
        printf("%d\n", dp[1][n]);
    }
    return 0;
}

 

POJ 2955 Brackets(区间DP)题解

标签:scanf   clu   def   using   map   i++   bre   algo   cstring   

原文地址:https://www.cnblogs.com/KirinSB/p/10317127.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!