zoukankan      html  css  js  c++  java
  • POJ 2955 Brackets(区间DP)题解

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

    思路:用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
    ", dp[1][n]);
        }
        return 0;
    }
  • 相关阅读:
    2、MapStruct 深入理解
    1、MapStruct的应用
    Spring中的注解
    java中的三个内置注解
    依赖注入集合属性
    List Set Map的特点
    为类类型的属性依赖注入值
    java常用专业术语
    Bean的作用域范围
    Bean的生命周期
  • 原文地址:https://www.cnblogs.com/KirinSB/p/10317127.html
Copyright © 2011-2022 走看看