uva673-括号平衡

小白书里数据结构基础的训练参考

翻译请戳 http://luckycat.kshs.kh.edu.tw/

解题思路

嗯。。。就是用栈。

出栈的时候不匹配、最后栈非空都是非法的表达式。

代码

#include<iostream>
#include<stdio.h>
#include<cstring>
#include<stack>
using namespace std;
const int MAX_LEN = 128+1;
int main()
{
    char operStr[MAX_LEN];
    int numStr;
    cin >> numStr;
    getchar();
    for(int i=0; i<numStr; i++) {
        stack<char> s;
        bool flag = true;
        gets(operStr);
        for(int j=0; j<strlen(operStr); j++) {
            if(operStr[j] == ‘(‘ || operStr[j] == ‘[‘) s.push(operStr[j]);
            else {
                if(operStr[j] == ‘]‘ && (s.empty() || !s.empty() && s.top() != ‘[‘)) {
                    flag = false; break;
                }
                if(operStr[j] == ‘)‘ && (s.empty() || !s.empty() && s.top() != ‘(‘)) {
                    flag = false; break;
                }
                s.pop();
            }
        }
        if(s.empty() && flag) cout << "Yes" << endl;
        else cout << "No" << endl;
    }
}
时间: 2024-07-29 12:24:29

uva673-括号平衡的相关文章

UVa 673 括号平衡

思路:简单的匹配操作,利用栈. Code: #include<stdio.h> #include<string.h> char stack[135]; int main() { int n; scanf("%d",&n); getchar(); while(n-->0) { memset(stack,0,sizeof(stack)); char c; int top=0; int flag=1; while((c=getchar())!='\n')

正则表达式30分钟入门教程

目录 跳过目录 本文目标 如何使用本教程 正则表达式到底是什么东西? 入门 测试正则表达式 元字符 字符转义 重复 字符类 分枝条件 反义 分组 后向引用 零宽断言 负向零宽断言 注释 贪婪与懒惰 处理选项 平衡组/递归匹配 还有些什么东西没提到 联系作者 网上的资源及本文参考文献 更新纪录 本文目标 30分钟内让你明白正则表达式是什么,并对它有一些基本的了解,让你可以在自己的程序或网页里使用它. 如何使用本教程 最重要的是--请给我30分钟,如果你没有使用正则表达式的经验,请不要试图在30秒内

【转】正则表达式30分钟入门教程

首页 | 常用正则表达式 | 正则表达式测试工具 正则表达式30分钟入门教程 版本:v2.33 (2013-1-10) 作者:deerchao 转载请注明来源 目录 跳过目录 本文目标 如何使用本教程 正则表达式到底是什么东西? 入门 测试正则表达式 元字符 字符转义 重复 字符类 分枝条件 反义 分组 后向引用 零宽断言 负向零宽断言 注释 贪婪与懒惰 处理选项 平衡组/递归匹配 还有些什么东西没提到 联系作者 网上的资源及本文参考文献 更新纪录 本文目标 30分钟内让你明白正则表达式是什么,

正则表达式学习(三)

零宽断言 地球人,是不是觉得这些术语名称太复杂,太难记了?我也有同感.知道有这么一种东西就行了,它叫什么,随它去吧!人若无名,便可专心练剑:物若无名,便可随意取舍-- 接下来的四个用于查找在某些内容(但并不包括这些内容)之前或之后的东西,也就是说它们像\b,^,$那样用于指定一个位置,这个位置应该满足一定的条件(即断言),因此它们也被称为零宽断言.最好还是拿例子来说明吧: 注:断言用来声明一个应该为真的事实.正则表达式中只有当断言为真时才会继续进行匹配. (?=exp)也叫零宽度正预测先行断言,

30分钟学会正则表达式

正则表达式30分钟入门教程 版本:v2.33 (2013-1-10) 作者:deerchao 转载请注明来源 原地址:http://www.jb51.net/tools/zhengze.html#mission 目录 跳过目录 本文目标 如何使用本教程 正则表达式到底是什么东西? 入门 测试正则表达式 元字符 字符转义 重复 字符类 分枝条件 反义 分组 后向引用 零宽断言 负向零宽断言 注释 贪婪与懒惰 处理选项 平衡组/递归匹配 还有些什么东西没提到 联系作者 网上的资源及本文参考文献 更新

Chapter 21_3 模式

很多地方都会看到各种匹配模式,每次接触这些函数,免不了望文生畏. 今天就来好好面对它.认识它.了解它.最后战胜它. 匹配模式都是用一串常规的字符串来描述,最主要的是理解这些字符串的语法及含义(即它能匹配到什么). ^$()%.[]*+-? 魔法字符,具有特殊的含义. %作为这些魔法字符的转义字符,还可以用于其他所有非字母和数字. %.    表示匹配一个"." %% 表示匹配一个“%” 当不确定一个字符是否需要转义时,应该前置一个转义符. . 所有字符 %a 字母 %c 控制字符 %d

Linux-正则表达式学习(精)

正则表达式30分钟入门教程 来园子之前写的一篇正则表达式教程,部分翻译自codeproject的The 30 Minute Regex Tutorial. 由于评论里有过长的URL,所以本页排版比较混乱,推荐你到原处查看,看完了如果有问题,再到这里来提出. 一些要说的话: 如果你没有正则表达式的基础,请跟着教程“一步步来”.请不要大概地扫两眼就说看不懂——以这种态度我写成什么样你也看不懂.当我告诉你这是“30分钟入门教程”时,请不要试图在30秒内入门. 事实是,我身边有个才接触电脑,对操作都不是

Lua 字符串

Lua 字符串 字符串或串(String)是由数字.字母.下划线组成的一串字符. Lua 语言中字符串可以使用以下三种方式来表示: 单引号间的一串字符. 双引号间的一串字符. [[和]]间的一串字符. 以上三种方式的字符串实例如下: string1 = "Lua" print("\"字符串 1 是\"",string1) string2 = 'runoob.com' print("字符串 2 是",string2) strin

正则表达式30分钟教程

本文目标 30分钟内让你明白正则表达式是什么,并对它有一些基本的了解,让你可以在自己的程序或网页里使用它. 如何使用本教程 最重要的是——请给我30分钟, 如果你没有使用正则表达式的经验,请不要试图在30秒内入门——除非你是超人 :) 别被下面那些复杂的表达式吓倒,只要跟着我一步一步来,你会发现正则表达式其实并没有你 想像中的那么困难.当然,如果你看完了这篇教程之后,发现自己明白了很多,却又几乎什么都记不得,那也是很正常的——我认为,没接触过正则表达式的人在看 完这篇教程后,能把提到过的语法记住

正则表达式30分钟入门教程 都是复制的

正则表达式30分钟入门教程 来园子之前写的一篇正则表达式教程,部分翻译自codeproject的The 30 Minute Regex Tutorial. 由于评论里有过长的URL,所以本页排版比较混乱,推荐你到原处查看,看完了如果有问题,再到这里来提出. 一些要说的话: 如果你没有正则表达式的基础,请跟着教程“一步步来”.请不要大概地扫两眼就说看不懂——以这种态度我写成什么样你也看不懂.当我告诉你这是“30分钟入门教程”时,请不要试图在30秒内入门. 事实是,我身边有个才接触电脑,对操作都不是