`
Simone_chou
  • 浏览: 195827 次
  • 性别: Icon_minigender_2
  • 来自: 广州
社区版块
存档分类
最新评论

括号匹配(二)(区间DP)

    博客分类:
  • NYOJ
 
阅读更多

括号匹配(二)

时间限制:1000 ms  |  内存限制:65535 KB
难度:6
 
描述
给你一个字符串,里面只包含"(",")","[","]"四种符号,请问你需要至少添加多少个括号才能使这些括号匹配起来。
如:
[]是匹配的
([])[]是匹配的
((]是不匹配的
([)]是不匹配的
 
输入
第一行输入一个正整数N,表示测试数据组数(N<=10)
每组测试数据都只有一行,是一个字符串S,S中只包含以上所说的四种字符,S的长度不超过100
输出
对于每组测试数据都输出一个正整数,表示最少需要添加的括号的数量。每组测试输出占一行
样例输入
4
[]
([])[]
((]
([)]
样例输出
0
0
3
2

 

     思路:

     区间 DP。设 dp [ i ] [ j ] 表示从 i 到 j 使其匹配成功的最小添加数量。所以:

     1.dp [ i ] [ j ] = min ( dp [ i ] [ j ] , dp [ i ] [ i + k ] + dp [ k + 1 ] [ j ] ) ( i <= k < j);

     2.若 s [ i ] 与 s [ j ] 是彼此匹配的括号时,还需要比较 dp [ i ] [ j ] = min ( dp [ i ] [ j ] ,dp [ i + 1] [ j - 1] )。

     初始化的时候,当 i == j 时,即为本身时,dp [ i ] [ j ] = 1;要求最小值,则当 i < j 时,dp [ i ] [ j ] = INF;当 i > j 时,dp [ i ] [ j ] = 0,这是需要注意的。

     比如当这个括号串为 “()”时,第一条 dp 公式更新到 dp [ 0 ][ 1 ] = 2,若把全部的值都初始化为 INF 的话,根据第二条 dp 更新公式,却得不到 0 的结果,因为 dp [ 1 ] [ 0 ] = INF,所以当 i > j 时,应该初始化 dp [ i ] [ j ] = 0 。

 

 

     AC:

#include <cstdio>
#include <cstring>
#include <algorithm>

using namespace std;

const int INF = 99999999;

int dp[105][105];

int main() {
        int n;
        scanf("%d", &n);
        while (n--) {
                char s[105];
                int len;
                scanf("%s", s);
                len = strlen(s);

                for (int i = 0; i < len; ++i)
                        for (int j = 0; j < len; ++j) {
                                if (i < j) dp[i][j] = INF;
                                if (i > j) dp[i][j] = 0;
                                if (i == j) dp[i][j] = 1;
                        }

                for (int j = 1; j < len; ++j) {
                        for (int i = j - 1; i >= 0; --i) {
                                for (int k = i; k < j; ++k) {
                                        dp[i][j] = min(dp[i][j], 
                                                       dp[i][k] + dp[k + 1][j]);
                                }
                                if (s[i] == '(' && s[j] == ')') 
                                    dp[i][j] = min(dp[i][j], dp[i + 1][j - 1]);
                                if (s[i] == '[' && s[j] == ']') 
                                    dp[i][j] = min(dp[i][j], dp[i + 1][j - 1]);
                        }
                }

                printf("%d\n", dp[0][len - 1]);
        }
        return 0;
}

 

 

分享到:
评论

相关推荐

    ACM算法与程序设计(十)1

    区间动态规划是一种在特定区间内进行的动态规划问题,它通常涉及计算一个二维数组`dp`,其中`dp[x][y]`表示区间 `[x, y]` 的解。 在区间动态规划中,有两种主要的状态转移方式: 1. 有些问题可以通过相邻状态直接...

    NOI/NOIP中的DP(动态规划)类型

    - **区间DP**:解决区间相关问题。 - **矩阵链乘法**:确定最佳矩阵相乘顺序。 - **游戏DP**:涉及两人或多人间的游戏策略问题。 ### DP状态转移方程实例 下面列出了一些典型的DP状态转移方程: 1. **0-1背包问题...

    juzhenliancheng.rar_juzhenliancheng

    同时,我们还可以通过回溯`dp`数组来恢复最优的矩阵乘法顺序,即最佳括号匹配形式。 在实际编程实现时,为了存储最优分割点,我们通常还需要一个二维数组`m`,`m[i][j]`记录了将区间[i...j]分成两部分时的最优分割...

    ACM竞赛模版

    2. **栈与队列**:基础数据结构,用于实现回溯、括号匹配等。 3. **树与图**:二叉树、平衡树(AVL、红黑树)、图的邻接矩阵和邻接表,用于处理层次关系和网络连接问题。 4. **哈希表**:提供快速查找、插入和删除...

    2008 年9 月全国计算机等级考试二级笔试试卷.

    - **栈的应用**:在实际编程中,栈被广泛应用于函数调用时保存返回地址、括号匹配问题等。 #### 1.2 队列的实现与理解 - **循环队列的特点**:循环队列利用数组模拟队列,解决了传统队列的假溢出问题。题目中强调了...

    Acm竞赛常用算法与数据结构

    3. 栈:后进先出(LIFO)结构,常用于括号匹配、回溯算法、递归等。 4. 队列:先进先出(FIFO)结构,用于BFS搜索、事件驱动模型等。 5. 树结构:二叉树、平衡树(AVL、红黑树)、B树、B+树等,常见于数据库索引、...

    编码测试::check_mark:알고리즘이

    在编码测试中,DFS常用于解决回溯问题,如迷宫求解、八皇后问题、括号匹配等。 4. **广度优先搜索(BFS)**:BFS是另一种遍历图或树的策略,它按照层次顺序访问节点。BFS常用于找出树的最短路径,或者在网络中寻找...

    Hot 100题 with Tags1

    11. **有效的括号**:栈的应用,检查字符串中的括号是否匹配。 12. **合并两个有序链表**:递归或迭代方式,将两个已排序的链表合并成一个有序链表。 13. **括号生成**:动态规划,生成所有有效的括号组合。 14. **...

    C语言算法集(C语言)

    - **栈**:"后进先出"(LIFO)的数据结构,常用于括号匹配、函数调用等。 - **队列**:"先进先出"(FIFO)的数据结构,常用于任务调度、缓冲区管理。 - **树**:层次结构,如二叉树、平衡树(AVL、红黑树)等,...

    ACM算法模板集史上最完整收藏版

    - 扩展了一维线段树的功能,用于处理二维空间中的区间查询。 - 在计算机图形学等领域有着广泛应用。 15. **稳定婚姻匹配**: - Gale-Shapley算法可以找到一个稳定的婚姻匹配。 - 在配对问题中有着重要应用。 ...

    4、NOIP提高组竞赛复试中需要用到的算法或涉及到知识点.pdf

    - 常出现在各种组合数学问题中,如括号序列的合法数目、二叉树的种类数量等。 6. **康拓展开** - 康拓展开是一种将非负整数映射到多项式系数的方法,常用于解决一些计数问题。 7. **负进制** - 负进制是基数...

    Leetcode-Questions:公司的Leetcode问题列表,包括高级问题。 2019年12月更新

    3. **栈(Stacks)**:利用栈的特性来解决逆序输出、括号匹配等问题。 4. **队列(Queues)**:例如实现循环队列、优先级队列等。 5. **字符串(Strings)**:涉及模式匹配、反转字符串、最长公共前后缀等。 6. *...

    ACM_算法模板程序设计协会ACM算法模板集.docxACM_算法模板程序设计协会ACM算法模板集ACM训练ACM集训算法入门参

    - **应用场景**:卡特兰数在计数问题中非常有用,如括号序列的有效配对数目等。 - **实现方式**:利用组合数学中的公式直接计算。 #### 4. Stirling Number (Second Kind) 斯特林第二类数 斯特林第二类数S(n,k)表示...

Global site tag (gtag.js) - Google Analytics