括号匹配的栈实现

括号匹配的栈实现

问题:判断一个文本中,括号是否匹配?

思路:从头到尾扫描字符串,每次遇到左括号(如‘(‘, ‘[‘, ‘{‘)就压入堆栈,如果遇到右括号(如‘)‘, ‘]‘, ‘}‘)就与栈顶元素比较,如果成对,OK,否则判断不匹配。

代码如下:

#include <iostream>
#include <stack>
#include <set>
#include <string>

using namespace std;

/*
 * vaild return true, else return false
 */
bool judge_bracket(const string & str)
{
    stack<char> st;

    set<char> left;
    set<char> right;

    left.insert(‘(‘);
    left.insert(‘[‘);
    left.insert(‘{‘);

    right.insert(‘)‘);
    right.insert(‘]‘);
    right.insert(‘}‘);

    for (int i=0; i!=str.size(); i++) {

        set<char>::iterator it1 = left.find(str[i]);
        set<char>::iterator it2 = right.find(str[i]);

        if (it1 != left.end()) {        // match left
            st.push(str[i]);

        } else if (it2 != right.end()) {    // match right

            if (st.size() == 0 ) return false;  // stack is empty

            if (str[i] - st.top() <= 2 ) {    // 右括号的ASCII码比其成对的左括号大1或2
                st.pop();

            } else {
                cout << "str[i]=" << str[i] << "top=" << st.top() <<endl;
                return false;
            }
        }
    }

    return true;
}

int main(int argc, char* argv[])
{
    string test_buffer[5] = {"]({[", "({[]})","([)]{}","(()[{}])","{[((()))]([])}"};

    //test
    for (int i=0; i<5; i++)
    {
        cout << "The string is \"" << test_buffer[i] << "\", The result is "
            << (judge_bracket(test_buffer[i]) ? "matched" : "not matched" ) << endl;
    }

    return 0;
}
时间: 2024-11-08 17:37:43

括号匹配的栈实现的相关文章

算法学习 - 括号匹配(栈实现)C++

括号匹配是栈最典型的应用了. 其实思路很简单,就是遇到一个左括号就压栈,遇到一个右括号就弹栈,看是否匹配就好了.最后检查下栈里是不是有剩余的括号就行了. 上代码~: // // main.cpp // bracketMatch // // Created by Alps on 14-7-28. // Copyright (c) 2014年 chen. All rights reserved. // #include <iostream> #define ElementType char usi

括号匹配(链栈实现)

/* 建立链栈实现括号匹配问题 创建栈,判断是否空栈 */ #include<stdio.h> #include<stdlib.h> #include<string.h> #define status int typedef struct node { char ch; node* next; }SNode; typedef struct { SNode *top; //SNode *base; }Stack; //创建空栈 base 赋值为NULL, top 指向栈顶

顺序栈(进制转换 + 括号匹配 + 判断栈表 + 最长括号匹配长度)

#include <stdio.h> #include <stdlib.h> #include <iostream> using namespace std; #define TRUE 1 #define FALSE 0 #define OK 1 #define ERROR 0 #define INFEASIBLE -1 #define OVERFLOW -2 #define STACK_INIT_SIZE 100 #define STACKLINCREMENT 10

OJ1147括号匹配加强版(栈)

惨兮兮的被刷掉2%的通过率后在经过思考和dalao的指点后终于A掉了这道题 强烈建议修改这题的样例,实在太迷惑人,各种错误算法都能过 比如说这是一份错误代码,看懂了也不要学思路,和正解不知道差到哪里去了: 惨兮兮,WA掉代码: #include <iostream> #include <iomanip> #include <cmath> #include <cstdio> #include <cstring> #include <algor

题目1153:括号匹配问题(栈的使用)

题目链接:http://ac.jobdu.com/problem.php?pid=1153 详解链接:https://github.com/zpfbuaa/JobduInCPlusPlus // // 1153 括号匹配问题.cpp // Jobdu // // Created by PengFei_Zheng on 08/04/2017. // Copyright © 2017 PengFei_Zheng. All rights reserved. // #include <stdio.h>

表达式括号匹配(栈)

1386: 表达式括号匹配 时间限制: 1 Sec  内存限制: 128 MB提交: 12  解决: 9[提交][状态][讨论版] 题目描述 假设一个表达式有英文字母(小写).运算符(+,-,*,/)和左右小(圆)括号构成,以"@"作为表达式的结束符.请编写一个程序检查表达式中的左右圆括号是否匹配,若匹配,则返回"YES":否则返回"NO".表达式长度小于255,左圆括号少于20个. 输入 包括一行数据,即表达式 输出 包括一行,即"Y

括号匹配(栈)

检查一段C语言代码的小括号( ). 中括号 [ ] 和大括号{ } 是否匹配. 输入格式: 在一行中输入一段C语言代码,长度不超过1000个字符(行末以换行符结束). 输出格式: 第一行输出左括号的数量和右括号的数量,中间以一个空格间隔.若括号是匹配的,在第二行打印YES,否则打印NO. 输入样例1: for(int i=0; i<v; i++){ visited[i] = 0; for(int j=0; j<v; j++) scanf("%d",&(g->A

括号匹配--java栈实现

假设括号都是(),{},[],{[]()},{()()}这种可以匹配的,存在{(}),([)均为错. 1 public boolean match(String str) { 2 //String str="[()()]{}"; 3 Stack <Character> s = new Stack<Character>(); 4 for (int index=0; index<str.length();index++) { 5 switch(str.char

nyoj 2 括号匹配(栈的基本运用)

括号配对问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描述 现在,有一行括号序列,请你检查这行括号是否配对. 输入 第一行输入一个数N(0<N<=100),表示有N组测试数据.后面的N行输入多组输入数据,每组输入数据都是一个字符串S(S的长度小于10000,且S不是空串),测试数据组数少于5组.数据保证S中只含有"[","]","(",")"四种字符 输出 每组输入数据的输出占一行,