题目大意:有一列只有'(',')','[',']'构成的括号序列,求在序列中至少加上多少括号,能使该序列合法。

解题思路:区间dp。

我们以$f[i][j]$表示把区间$[i,j]$添成合法括号所需的最小括号数。

设某段序列为$S_0$,它对应区间为$[i,j]$,括号数为$f[i][j]$.

若$S_0$形如$(S_1)$或$[S_1]$,$f[i][j]=min\{f[i][j],f[i+1][j−1]\}$;即令$S_1$合法后,$S_0$可合法。

若$S_0$形如$(S_1$或$[S_1$,$f[i][j]=min\{f[i][j],f[i+1][j]+1\}$;即令$S_1$合法后,$S_0$可在最后添加一个括号后合法。

同理,若$S_0$形如$S_1)$或$S_1]$,

$f[i][j]=min\{f[i][j],f[i][j-1]+1\}$;
无论$S_0$是什么情况,都有$f[i][j]=min\{f[i][j],f[i][k]+f[k+1][j]\},i≤k<j$;

即把序列分成两部分分别使其合法。

这样的时间复杂度为$O(n^3)$。

注意i要倒着循环,否则可能会出现某些情况还没计算就要使用的情况。

C++ Code:

  1. #include<cstdio>
  2. #include<cstring>
  3. #define min(a,b) (((a)<(b))?(a):(b))
  4. char s[120];
  5. int f[120][120];
  6. int main(){
  7. scanf("%s",s+1);
  8. int n=strlen(s+1);
  9. memset(f,0,sizeof f);
  10. for(int i=1;i<=n;++i){
  11. f[i][i]=1;
  12. for(int j=i+1;j<=n;++j)f[i][j]=0x3f3f3f3f;
  13. }
  14. for(int i=n;i;--i){
  15. for(int j=i+1;j<=n;++j){
  16. if(s[i]=='('&&s[j]==')'||s[i]=='['&&s[j]==']')
  17. f[i][j]=f[i+1][j-1];
  18. if(s[i]=='('||s[i]=='[')
  19. f[i][j]=min(f[i][j],f[i+1][j]+1);
  20. if(s[i]==')'||s[i]==']')
  21. f[i][j]=min(f[i][j],f[i][j-1]+1);
  22. for(int k=i;k<j;++k)
  23. f[i][j]=min(f[i][j],f[i][k]+f[k+1][j]);
  24. }
  25. }
  26. printf("%d\n",f[1][n]);
  27. return 0;
  28. }

[codevs3657]括号序列的更多相关文章

  1. 【区间DP】codevs3657 括号序列题解

    题目描述 Description 我们用以下规则定义一个合法的括号序列: (1)空序列是合法的 (2)假如S是一个合法的序列,则 (S) 和[S]都是合法的 (3)假如A 和 B 都是合法的,那么AB ...

  2. BZOJ4350: 括号序列再战猪猪侠

    Description 括号序列与猪猪侠又大战了起来. 众所周知,括号序列是一个只有(和)组成的序列,我们称一个括号 序列S合法,当且仅当: 1.( )是一个合法的括号序列. 2.若A是合法的括号序列 ...

  3. DP专题——括号序列

    毕竟是个渣,写完一遍之后又按LRJ的写了一遍,再写了一遍递归版,最终加上输出解部分 括号序列 定义如下规则序列(字符串): 空序列是规则序列: 如果S是规则序列,那么(S)和[S]也是规则序列: 如果 ...

  4. 【BZOJ】2209: [Jsoi2011]括号序列(splay)

    http://www.lydsy.com/JudgeOnline/problem.php?id=2209 splay又犯逗........upd1那里的sum忘记赋值反............. 本题 ...

  5. 51nod1476 括号序列的最小代价

    这题应该可以用费用流写吧?不过我想不出贪心来TAT.其实还是单调队列乱搞啊T_T //ÍøÉϵÄÌ°ÐÄËã·¨ºÃÉñ°¡¡£¡£¡£ÎÒÖ»»áÓÃ×îС·ÑÓÃ×î´óÁ÷ÅÜTAT #in ...

  6. lintcode: 有效的括号序列

    题目: 有效的括号序列 给定一个字符串所表示的括号序列,包含以下字符: '(', ')', '{', '}', '[' and']', 判定是否是有效的括号序列. 样例 括号必须依照 "() ...

  7. uoj #31. 【UR #2】猪猪侠再战括号序列 贪心

    #31. [UR #2]猪猪侠再战括号序列 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://uoj.ac/problem/31 Descript ...

  8. bzoj 1095 [ZJOI2007]Hide 捉迷藏(括号序列+线段树)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1095 [题意] 给定一棵树,树上颜色或白或黑而且可以更改,多个询问求最远黑点之间的距离 ...

  9. CODEVS 3657 括号序列

    [问题描述] 我们用以下规则定义一个合法的括号序列: (1)空序列是合法的 (2)假如S是一个合法的序列,则 (S) 和[S]都是合法的 (3)假如A 和 B 都是合法的,那么AB和BA也是合法的 例 ...

随机推荐

  1. python简单的购物系统

    #coding = utf-8 #2016-11-19#我的工资是存在文件中的,执行后会判断是否存过工资,如果存过无需输入,直接购物,没存过需要输入工资#wages.txt是存工资的文件 import ...

  2. css——导航栏

    导航栏一般用无序列表制作 但出来的导航栏有黑点,还有一些边距 去除黑点我们可以用:list-style-type: none;/*去掉ul前面的点*/ 因为有些标签之间会有默认的边距,所以可以先将边踞 ...

  3. jq——html,text,val和对象访问

    html代码 1.html():获取的是对象内的html代码,类似于innerHTML 2.html(代码):设置html的内容,替换 $("div").html("hh ...

  4. P3387 【模板】缩点 && P3388 【模板】割点(割顶)

    Tarjan算法 应用: 有向图的强连通分量 无向图割点和桥 双连通分量 接下来主要谈论前面两者的应用(主要是第三种还没学会) 算法简要介绍 我们需要先理解一下知识:搜索树 有向图的搜索树的4种边,如 ...

  5. SPOJ CIRU

    SPOJ CIRU 题意 给出n个圆,求他们覆盖的面积. 解法 自适应Simpson,但需要将圆离散化一下,以保证我们查询的是一个连续的有圆的区间. 奇怪的是我没有离散化,样例都没有过,却把题给A了 ...

  6. python基础,函数,面向对象,模块练习

    ---恢复内容开始--- python基础,函数,面向对象,模块练习 1,简述python中基本数据类型中表示False的数据有哪些? #  [] {} () None 0 2,位和字节的关系? # ...

  7. NYIST 1030 Yougth's Game[Ⅲ]

    Yougth's Game[Ⅲ]时间限制:3000 ms | 内存限制:65535 KB难度:4 描述有一个长度为n的整数序列,A和B轮流取数,A先取,每次可以从左端或者右端取一个数,所有数都被取完时 ...

  8. HDU 4335 Contest 4

    利用降幂公式..呃,还是自己去搜题解吧.知道降幂公式后,就不难了. #include <iostream> #include <cstdio> #include <alg ...

  9. hdu Swipe Bo(bfs+状态压缩)错了多次的题

    Swipe Bo Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total S ...

  10. EditText电话号码格式化输入、删除案例

    我们在输入电话号码的时候,一般都会切割一个较长的电话号码.这种话效果会好非常多..对EditText的监听能够轻松的实现这个需求.仅仅须要我们给相应的EditText加一个监听就OK了..贴一下我写的 ...