Java [leetcode 20]Valid Parentheses
题目描述:
Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the input string is valid.
The brackets must close in the correct order, "()" and "()[]{}" are all valid but "(]" and "([)]" are not.
解题思路:
Java现在不采用Stack栈了,那么我们用ArrayList替代之。
利用ArrayList来保存前括号,遇到后括号的情况就弹出ArrayList末尾数据,与之匹配。
若全部匹配,则最后是能够完全匹配的话,ArrayList应该为空。若不为空,则说明没有完全匹配。
代码如下:
public boolean isValid(String s) {
		ArrayList<Character> list = new ArrayList<Character>();
		for (int i = 0; i < s.length(); i++) {
			if (s.charAt(i) == ')' || s.charAt(i) == ']' || s.charAt(i) == '}') {
				if (list.isEmpty())
					return false;
				else {
					char tmp = list.get(list.size() - 1);
					list.remove(list.size() - 1);
					if ((s.charAt(i) == ')' && tmp != '(')
							|| (s.charAt(i) == ']' && tmp != '[')
							|| (s.charAt(i) == '}' && tmp != '{'))
						return false;
				}
			} else {
				list.add(s.charAt(i));
			}
		}
		return list.isEmpty();
	}
Java [leetcode 20]Valid Parentheses的更多相关文章
- leetcode 20. Valid Parentheses 、32. Longest Valid Parentheses 、
		20. Valid Parentheses 错误解法: "[])"就会报错,没考虑到出现')'.']'.'}'时,stack为空的情况,这种情况也无法匹配 class Soluti ... 
- [LeetCode] 20. Valid Parentheses 验证括号
		Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the inpu ... 
- [LeetCode] 20. Valid Parentheses 合法括号
		Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the inpu ... 
- [leetcode]20. Valid Parentheses有效括号序列
		Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the inpu ... 
- leetCode 20.Valid Parentheses (有效的括号) 解题思路和方法
		Valid Parentheses Given a string containing just the characters '(', ')', '{', '}', '[' and ']', de ... 
- leetcode 20 Valid Parentheses 括号匹配
		Given a string containing just the characters '(', ')', '{', '}', '[' and']', determine if the input ... 
- [LeetCode] 20. Valid Parentheses ☆
		转载:https://leetcode.windliang.cc/leetCode-20-Valid%20Parentheses.html 描述 Given a string containing j ... 
- LeetCode 20 Valid Parentheses (括号匹配问题)
		题目链接 https://leetcode.com/problems/valid-parentheses/?tab=Description Problem: 括号匹配问题. 使用栈,先进后出! ... 
- 蜗牛慢慢爬 LeetCode 20. Valid Parentheses [Difficulty: Easy]
		题目 Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the i ... 
随机推荐
- fragment第二次载入就报错
			1.布局中加入一个<fragment 标签,第一次载入的时候是正常的,第二次加载的时候,就直接crashed,退出 2.查到原因Caused by: java.lang.IllegalArgum ... 
- WRS是什么?
			全球参考系(WRS)是为卫星下行数据服务而建立的一种全球符号坐标系统,本文详细介绍了Landsat卫星的轨道特性,给出了相应的WRS网格坐标位置的估算方法,并给出了估算的结果。对该方法的研究为地面应用 ... 
- 六、mysql字段类型选择
			.char类型字段会自动删除字符串后面所带的空格,而varchar不会 .char比varchar快..... .myisam 建议 char类型,memory char跟varchar一样,都作为c ... 
- PHP视频教程 > PHP面向对象编程视频教程
			当前位置: 主页 > 编程开发 > PHP视频教程 > PHP面向对象编程视频教程 > kingstone金士顿手机内存卡16G仅65元 1.1.什么是面向对象和类 上传日期: ... 
- You have new mail in /var/spool/mail/root 烦不烦你?
			http://blog.csdn.net/yx_l128125/article/details/7425182 
- 使用Yeoman搭建 AngularJS 应用 (7) —— 让我们搭建一个网页应用
			原文地址:http://yeoman.io/codelab/preview-inbrowser.html 开启你的服务 运行Grunt任务,通过输入下面的命令来创建一个本地Node的http服务,地址 ... 
- setTimeout浅析
			刚学习javascript的时候,感觉setTimeout很好理解,不就是过n(传入的毫秒数)毫秒,执行以下传入的函数吗?这个理解伴随了我挺长的一段时间,才对setTimeout有了新的认识,请先看下 ... 
- 一个UUID生成算法的C语言实现 --- WIN32版本 .
			一个UUID生成算法的C语言实现——WIN32版本 cheungmine 2007-9-16 根据定义,UUID(Universally Unique IDentifier,也称GUID)在时 ... 
- Makefile教程
			Makefile学习教程: 跟我一起写 Makefile 0 Makefile概述 0.1 关于程序的编译和链接 1 Makefile 介绍 1.1 Makefile的规则 1.2 一个示例 1.3 ... 
- http://www.linuxidc.com/Linux/2007-09/7399.htm
			http://www.linuxidc.com/Linux/2007-09/7399.htm 
