【栈思想、DP】NYOJ-15 括号匹配(二)
括号匹配(二)
- 给你一个字符串,里面只包含"(",")","[","]"四种符号,请问你需要至少添加多少个括号才能使这些括号匹配起来。
如:
[]是匹配的
([])[]是匹配的
((]是不匹配的
([)]是不匹配的
- 第一行输入一个正整数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 括号匹配(二)的更多相关文章
- nyoj 15 括号匹配(二) (经典dp)
题目链接 描述 给你一个字符串,里面只包含"(",")","[","]"四种符号,请问你需要至少添加多少个括号才能使这些 ...
- [NYOJ 15] 括号匹配(二)
括号匹配(二) 时间限制:1000 ms | 内存限制:65535 KB 难度:6 描述 给你一个字符串,里面只包含"(",")","[&qu ...
- nyoj 15 括号匹配(2)
括号匹配(二) 时间限制:1000 ms | 内存限制:65535 KB 难度:6 描述 给你一个字符串,里面只包含"(",")","[" ...
- nyoj 15 括号匹配(二)动态规划
当时看到(二)就把(一)做了, 一很容易,这道题纠结了好几天,直到今晚才看懂别人的代码谢,勉强才写出来.................... 不愧是难度6的题. #include <stdio ...
- SDUT-2134_数据结构实验之栈与队列四:括号匹配
数据结构实验之栈与队列四:括号匹配 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 给你一串字符,不超过50个字符,可能 ...
- NYOJ 题目15 括号匹配(二)(区间DP)
点我看题目 题意 : 中文题不详述. 思路 : 本来以为只是个小模拟,没想到是个区间DP,还是对DP不了解. DP[i][j]代表着从字符串 i 位置到 j 位置需要的最小括号匹配. 所以初始化的DP ...
- 南阳理工大学oj 题目15 括号匹配(二)
括号匹配(二) 时间限制:1000 ms | 内存限制:65535 KB 难度:6 描述 给你一个字符串,里面只包含"(",")","[&qu ...
- 栈的应用:表达式括号匹配检测(C)
问题说明: 假设数学表达式中允许包含两种括号:圆括号"()"和方括号"[]",嵌套顺序任意. 正确的嵌套模式:( [ ] ( ) ).[ ( [ ] [ ] ) ...
- 区间dp模型之括号匹配打印路径 poj(1141)
题目链接:Brackets Sequence 题目描写叙述:给出一串由'(')'' [ ' ' ] '组成的串,让你输出加入最少括号之后使得括号匹配的串. 分析:是区间dp的经典模型括号匹配.解说:h ...
随机推荐
- vs2010中臃肿的ipch和sdf文件
使用VS2010建立C++解决方案时,会生成SolutionName.sdf和一个叫做ipch的文件夹,这两个文件再加上*.pch等文件使得工程变得非常的庞大,一个简单的程序都会占用几十M的硬盘容量, ...
- 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 ...
- uva 10994
一开始想法太简单 错了好多遍 #include <cstdio> #include <cstdlib> #include <cmath> #include < ...
- c# 组元(Tuple)
组元是C# 4.0引入的一个新特性,编写的时候需要基于.NET Framework 4.0或者更高版本.组元使用泛型来简化一个类的定义. 先以下面的一段代码为例子: public class Poin ...
- jQuery动画效果实现
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...
- MySQL错误代码大全【转载】
B.1. 服务器错误代码和消息 服务器错误信息来自下述源文件: 错误消息信息列在share/errmsg.txt文件中."%d"和"%s"分别代表编号和字符串, ...
- JavaWeb项目开发案例精粹-第3章在线考试系统-004Service层
1. package com.sanqing.service; import java.util.List; import com.sanqing.po.Student; public interfa ...
- React组件测试(模拟组件、函数和事件)
一.模拟组件 1.用到的工具 (1)browerify (2)jasmine-react-helpers (3)rewireify(依赖注入) (4)命令:browserify - t reactif ...
- Java多线程4:synchronized关键字
原文:http://www.cnblogs.com/skywang12345/p/3479202.html 1. synchronized原理在java中,每一个对象有且仅有一个同步锁.这也意味着,同 ...
- shell编程基础(4)case 与 function
case case语句不用多说和c++里一样,用作选择,但是linux的case语句在语法上和c++还是有些不同的. ###########This is program test the Case# ...