括号匹配--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.charAt(index)) {
 6             case ‘(‘:
 7                 s.push(str.charAt(index));
 8                 break;
 9             case ‘[‘:
10                 s.push(str.charAt(index));
11                 break;
12             case ‘{‘:
13                 s.push(str.charAt(index));
14                 break;
15             case ‘)‘:
16                 if(s.peek().equals(‘)‘)&& (!s.empty()) ) {
17                     s.pop();
18                 }
19                 break;
20             case ‘]‘:
21                 if(s.peek().equals(‘]‘)&& (!s.empty()) ) {
22                     s.pop();
23                 }
24                 break;
25             case ‘}‘:
26                 if(s.peek().equals(‘}‘)&& (!s.empty()) ) {
27                     s.pop();
28                 }
29                 break;
30             }
31         }
32         if(s.empty()) {
33             return true;
34         }
35         return false;
36     }

原文地址:https://www.cnblogs.com/Suntree/p/11552361.html

时间: 2024-11-07 08:14:48

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

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

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

括号匹配的栈实现

括号匹配的栈实现 问题:判断一个文本中,括号是否匹配? 思路:从头到尾扫描字符串,每次遇到左括号(如'(', '[', '{')就压入堆栈,如果遇到右括号(如')', ']', '}')就与栈顶元素比较,如果成对,OK,否则判断不匹配. 代码如下: #include <iostream> #include <stack> #include <set> #include <string> using namespace std; /* * vaild retu

括号匹配(链栈实现)

/* 建立链栈实现括号匹配问题 创建栈,判断是否空栈 */ #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

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

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