括号匹配(二)

描述
给你一个字符串,里面只包含"(",")","[","]"四种符号,请问你需要至少添加多少个括号才能使这些括号匹配起来。
如:
[]是匹配的
([])[]是匹配的
((]是不匹配的
([)]是不匹配的
输入
第一行输入一个正整数N,表示测试数据组数(N<=10)
每组测试数据都只有一行,是一个字符串S,S中只包含以上所说的四种字符,S的长度不超过100
输出
对于每组测试数据都输出一个正整数,表示最少需要添加的括号的数量。每组测试输出占一行
样例输入
4
[]
([])[]
((]
([)]
样例输出
0
0
3
2
【分析】
  可以运用类似栈的思想。
    1.如果是 '(' || '[' 则压栈。
    2.如果是')' || ']' 并且栈顶元素与之相匹配则将栈顶pop。
    3.如果条件2的反例,则进入循环,将当前读入的元素与栈中每个元素进行比较。
      3.1 如果匹配则跳出循环并且sum加上已尝试匹配的个数。
      3.2 如果读到栈底也不匹配则sum+1。
    4.输出结果应为 sum+“栈”中元素个数
    所以其实不能用栈来做,因为要和栈中每个元素进行挨个比较,栈没有这个操作,所以应该用两个数组,来模拟栈的操作。
  例如:(以下的“栈”应理解为数组)
    ((]))  首先将((压入“栈”,(执行第3步),然后“]”依次与“栈”中的 (( 进行比较,比较到栈底也没有元素与之相匹配(3.2),所以sum++,继续读入)),执行第2步。
      输出的答案即为1
    (([))  首先将(([压入“栈”,(执行第3步),然后“)”依次与“栈”中的 (([ 进行比较,比较到第一个 ( 时,与当前元素相匹配,跳出循环(3.1)。
      输出答案即为1
  好吧,啰嗦这么多,我也表达不清了,上代码!
【代码】
  
 #include<cstdio>
#include<cstring>
int main(){
int n;
scanf("%d",&n);
while(n--){
char arry[] = {''},stack[] = {''};
scanf("%s",arry);
int len = strlen(arry),i,flag,temp,sum = ;
int top = ,k;
for(i = ;i < len;i++){
temp = flag = ;
k = top;
if(arry[i] == '(' || arry[i] == '[')
stack[top++] = arry[i];
else if(arry[i] == ')' && stack[top - ] == '(' || arry[i] == ']' && stack[top - ] == '['){
top--;
}else{
while(k!=){
if(arry[i] == ')' && stack[k - ] == '(' || arry[i] == ']' && stack[k - ] == '['){
temp = ;
top = k - ;
break;
}else{
flag += ;
}
k--;
}
if(!temp)
sum += ;
else
sum += flag;
}
}
sum += top;
printf("%d\n",sum);
}
return ;
}

当然也可以用DP的思想,先挖好坑,待研究。。。

【栈思想、DP】NYOJ-15 括号匹配(二)的更多相关文章

  1. nyoj 15 括号匹配(二) (经典dp)

    题目链接 描述 给你一个字符串,里面只包含"(",")","[","]"四种符号,请问你需要至少添加多少个括号才能使这些 ...

  2. [NYOJ 15] 括号匹配(二)

    括号匹配(二) 时间限制:1000 ms  |  内存限制:65535 KB 难度:6   描述 给你一个字符串,里面只包含"(",")","[&qu ...

  3. nyoj 15 括号匹配(2)

    括号匹配(二) 时间限制:1000 ms  |  内存限制:65535 KB 难度:6 描述 给你一个字符串,里面只包含"(",")","[" ...

  4. nyoj 15 括号匹配(二)动态规划

    当时看到(二)就把(一)做了, 一很容易,这道题纠结了好几天,直到今晚才看懂别人的代码谢,勉强才写出来.................... 不愧是难度6的题. #include <stdio ...

  5. SDUT-2134_数据结构实验之栈与队列四:括号匹配

    数据结构实验之栈与队列四:括号匹配 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 给你一串字符,不超过50个字符,可能 ...

  6. NYOJ 题目15 括号匹配(二)(区间DP)

    点我看题目 题意 : 中文题不详述. 思路 : 本来以为只是个小模拟,没想到是个区间DP,还是对DP不了解. DP[i][j]代表着从字符串 i 位置到 j 位置需要的最小括号匹配. 所以初始化的DP ...

  7. 南阳理工大学oj 题目15 括号匹配(二)

    括号匹配(二) 时间限制:1000 ms  |  内存限制:65535 KB 难度:6   描述 给你一个字符串,里面只包含"(",")","[&qu ...

  8. 栈的应用:表达式括号匹配检测(C)

    问题说明: 假设数学表达式中允许包含两种括号:圆括号"()"和方括号"[]",嵌套顺序任意. 正确的嵌套模式:( [ ] ( ) ).[ ( [ ] [ ] ) ...

  9. 区间dp模型之括号匹配打印路径 poj(1141)

    题目链接:Brackets Sequence 题目描写叙述:给出一串由'(')'' [ ' ' ] '组成的串,让你输出加入最少括号之后使得括号匹配的串. 分析:是区间dp的经典模型括号匹配.解说:h ...

随机推荐

  1. vs2010中臃肿的ipch和sdf文件

    使用VS2010建立C++解决方案时,会生成SolutionName.sdf和一个叫做ipch的文件夹,这两个文件再加上*.pch等文件使得工程变得非常的庞大,一个简单的程序都会占用几十M的硬盘容量, ...

  2. Codeforces Round #241 (Div. 2)->B. Art Union

    B. Art Union time limit per test 1 second memory limit per test 256 megabytes input standard input o ...

  3. uva 10994

    一开始想法太简单  错了好多遍 #include <cstdio> #include <cstdlib> #include <cmath> #include < ...

  4. c# 组元(Tuple)

    组元是C# 4.0引入的一个新特性,编写的时候需要基于.NET Framework 4.0或者更高版本.组元使用泛型来简化一个类的定义. 先以下面的一段代码为例子: public class Poin ...

  5. jQuery动画效果实现

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  6. MySQL错误代码大全【转载】

    B.1. 服务器错误代码和消息 服务器错误信息来自下述源文件: 错误消息信息列在share/errmsg.txt文件中."%d"和"%s"分别代表编号和字符串, ...

  7. JavaWeb项目开发案例精粹-第3章在线考试系统-004Service层

    1. package com.sanqing.service; import java.util.List; import com.sanqing.po.Student; public interfa ...

  8. React组件测试(模拟组件、函数和事件)

    一.模拟组件 1.用到的工具 (1)browerify (2)jasmine-react-helpers (3)rewireify(依赖注入) (4)命令:browserify - t reactif ...

  9. Java多线程4:synchronized关键字

    原文:http://www.cnblogs.com/skywang12345/p/3479202.html 1. synchronized原理在java中,每一个对象有且仅有一个同步锁.这也意味着,同 ...

  10. shell编程基础(4)case 与 function

    case case语句不用多说和c++里一样,用作选择,但是linux的case语句在语法上和c++还是有些不同的. ###########This is program test the Case# ...