zoukankan      html  css  js  c++  java
  • 20. 有效的括号

    一、题目

    原题链接: https://leetcode-cn.com/problems/valid-parentheses/

    给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。

    有效字符串需满足:

    1、左括号必须用相同类型的右括号闭合
    2、左括号必须以正确的顺序闭合

    示例 1:

    输入: "()"
    输出: true

    示例 2:

    输入: "()[]{}"
    输出: true

    示例 3:

    输入: "(]"
    输出: false

    示例 4:

    输入: "([)]"
    输出: false

    示例 5:

    输入: "{[]}"
    输出: true

    二、思路及解法

    此题类似于寻找对称的字符,此处可以用栈来处理

    1、遍历字符串,先让左括号入栈
    2、当遍历到右边符号时,先判断栈顶元素是否为对应的左括号,如果不是,则返回false
    3、如果是对应的左括号,则左括号出栈
    4、继续遍历,直到栈为空,则返回true

    public class N20 {
    
    	public static void main(String[] args) {
    		String s = "()[]{}";
    		s = "{()[]}";
    		System.out.println(isValid(s));
    	}
    	
    	public static boolean isValid(String s) {
    		Stack<Character> stack = new Stack<Character>();
    		if(s.length() % 2 != 0){
    			return false;
    		}
    		for(int i = 0 ; i < s.length() ; i++){
    			char c = s.charAt(i);
    			if(c == '(' || c == '[' || c == '{'){
    				stack.push(c);
    			}else{
    				if(stack.isEmpty()){
    					return false;
    				}
    				if(c == ')' && stack.peek() != '('){
    					return false;
    				}
    				if(c == ']' && stack.peek() != '['){
    					return false;
    				}
    				if(c == '}' && stack.peek() != '{'){
    					return false;
    				}
    				stack.pop();
    			}
    		}
    		return stack.isEmpty();
    	}
    
    }
    
  • 相关阅读:
    6次作业
    5次作业
    4次作业
    3次作业
    first 作业
    pycharm快捷键
    python基础知识记录
    Jenkins+sonar+tomcat+SVN集成搭建
    成为1个技术大牛的入门到进阶之路(学习路线图)
    记一次收到QQ邮箱钓鱼邮件经历
  • 原文地址:https://www.cnblogs.com/lmj612/p/12891243.html
Copyright © 2011-2022 走看看