[LeetCode][Java] Valid Parentheses

原创 2015年07月10日 11:16:59

题目:

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.


题意:

给定一个字符串,包含以下字符'('')''{''}''[' and ']',判断输入的字符串是否有效。

这些括号必须按正确的顺序关闭,"()" and "()[]{}"就是有效的,"(]" and "([)]" 就是无效的。

算法分析:

该题是匹配括号是否匹配合法问题,可以采用栈来实现,而栈一般采用数组来进行标示。如果遇到字符(,{[,则将其压入栈中,如果遇到),}],则需要对栈顶元素进行判定,看是否与括号相匹配,如果匹配则弹出栈顶元素,否则则认为匹配不合法,直接结束匹配过程。

算法流程如下:

定义数组栈stack;
foreach c in String:
    if c 为(,{,[  then stack.push(c);
    if c 为 ), }, ]    then 判定stack是否为空和stack.top是否与c相匹配。

AC代码:

public class Solution 
{

	private  boolean a;
	private  boolean flag;
	private  int i;
	private  int n;

	public  boolean isValid(String s) 
    {

        Stack st= new Stack(); // 创建堆栈对象
        if (s.length()%2!=0) flag=false;
        else
        { 
        	i=0;
        	st.push(s.charAt(0));
	        while (i<s.length()-1)
	        {
	        	if(st.empty())
	        	{
	        		st.push(s.charAt(i+1));
	        		i++;
	        	}
	        	
	            if((st.peek().toString().charAt(0)=='('&&s.charAt(i+1)==')')||(st.peek().toString().charAt(0)=='['&&s.charAt(i+1)==']'                          )||(st.peek().toString().charAt(0)=='{'&&s.charAt(i+1)=='}'))
	        	{
	        		st.pop();
	        	}
	        	else
	        	    st.push(s.charAt(i+1));
	        	i++;
	        }
	        flag=st.empty();
        }
        return flag;
    }
}


版权声明:本文为博主原创文章,转载注明出处

LeetCode(20) Valid Parentheses

题目如下 Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the...
  • feliciafay
  • feliciafay
  • 2013年12月19日 06:04
  • 2884

LeetCode 20 : Valid Parentheses (Java)

解题思路:这是一道典型的可以用栈来解决的问题。做一个空栈。一个个读入字符直到字符串结尾。如果字符是一个开放符号,则将其推入栈中。如果字符是一个封闭符号,则当栈空时报错。否则,将栈元素弹出。如果弹出的符...
  • changetocs
  • changetocs
  • 2015年12月02日 10:53
  • 467

LeetCode 20 Valid Parentheses (C,C++,Java,Python)

Problem: Given a string containing just the characters '(', ')', '{', '}', '[' and ']', deter...
  • runningtortoises
  • runningtortoises
  • 2015年05月10日 16:41
  • 2657

LeetCode 20 — Valid Parentheses(C++ Java Python)

题目:http://oj.leetcode.com/problems/valid-parentheses/ Given a string containing just the characters ...
  • dragon_dream
  • dragon_dream
  • 2014年03月21日 09:37
  • 2945

[leetcode-32]Longest Valid Parentheses(java)

问题描述: Given a string containing just the characters ‘(’ and ‘)’, find the length of the longest val...
  • zdavb
  • zdavb
  • 2015年09月01日 16:54
  • 553

C实现 LeetCode->Valid Parentheses

Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the inpu...
  • liutianshx2012
  • liutianshx2012
  • 2015年06月17日 09:51
  • 531

[LeetCode]Valid Parentheses

题目要求如下: Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determ...
  • zhouworld16
  • zhouworld16
  • 2013年12月28日 11:45
  • 8702

LeetCode(32)Longest Valid Parentheses

题目如下: Given a string containing just the characters '(' and ')', find the length of the longest vali...
  • feliciafay
  • feliciafay
  • 2014年03月07日 08:31
  • 1749

Valid Parentheses python题解

Valid Parentheses python题解
  • xiaolewennofollow
  • xiaolewennofollow
  • 2015年04月20日 12:31
  • 990

Leetcode c语言-Valid Parentheses

Title: Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determi...
  • hahachenchen789
  • hahachenchen789
  • 2017年09月17日 22:46
  • 311
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[LeetCode][Java] Valid Parentheses
举报原因:
原因补充:

(最多只允许输入30个字)