算法题:括号匹配(小中大括号序列)

Posted jobbible

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了算法题:括号匹配(小中大括号序列)相关的知识,希望对你有一定的参考价值。

括号序列由( )[ ]{ }组成,不合法的括号序列由( { ) },[ } { ],等等。编程实现一个函数,检查一个括号序列是否是合法的括号序列。

解法:

思路和“后缀表达式的求解”相似。我们借助栈,每读一个括号,如果是左括号,那么入栈,然后继续读下一个括号;如果是右括号,那么就要看看这个右括号和栈顶的括号是否匹配;如果匹配,那么弹出栈顶的括号,继续读下一个括号。当栈变空时,说明此括号序列是合法的。
 

public class Test05 {
 
	public static boolean isValid(String exp) {
		String left = "([{";
		String right = ")]}";
		Stack<Character> s = new Stack<Character>();
		for (int i = 0, len = exp.length(); i < len; i++) {
			char ch = exp.charAt(i);
			if (left.indexOf(ch) != -1) {
				s.push(ch);
			}
			else if (right.indexOf(ch) != -1) {
				if (!s.isEmpty()) {
					char temp = s.pop();
					if (ch != right.charAt(left.indexOf(temp))) {
						return false;
					}
				}
				else {
					return false;
				}
			}
		}
		return s.isEmpty();
	}
 
	public static void main(String[] args) {
		System.out.println(isValid("([()]{})"));
		System.out.println(isValid("((){}"));
		System.out.println(isValid("[{)()]"));
	}
 
}
 

  


以上是关于算法题:括号匹配(小中大括号序列)的主要内容,如果未能解决你的问题,请参考以下文章

括号匹配

一个算法题:括号匹配问题。

python程序括号为啥变绿

百度的一道二面算法题分析:补全括号序列

试编写一个算法从检查一个Java语言中的大括号方括号小括号是不是配对,若能够全?

最强解析面试题:合法序括号序列判断