码迷,mamicode.com
首页 > 其他好文 > 详细

LeetCode刷题记录_有效的括号

时间:2018-07-28 18:22:23      阅读:115      评论:0      收藏:0      [点我收藏+]

标签:char   包括   sha   tac   else   put   boolean   nta   code   

题目:

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

有效字符串需满足:

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

注意空字符串可被认为是有效字符串。

示例 1:

输入: "()"
输出: true

示例 2:

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

示例 3:

输入: "(]"
输出: false

示例 4:

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

示例 5:

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

用栈的思想来解决最简单了,可惜stack完全没用过,用LinkedList模仿堆栈:

class Solution {
    public boolean isValid(String s) {
        LinkedList<Character> list= new LinkedList<>();
        Map<Character,Character> map = new HashMap<>();
        map.put(‘}‘,‘{‘);
        map.put(‘)‘,‘(‘);
        map.put(‘]‘,‘[‘);
        int len= s.length();
        
        for(int i=0;i<len;i++){
            Character ch = new Character(s.charAt(i));
            if(!map.containsKey(ch)||list.size()==0)
                list.addLast(ch);
            else{
                if(list.get(list.size()-1).equals(map.get(ch)))
                    list.removeLast();
                else
                    return false;
            }            
        }
       return list.isEmpty()?ture:false;
        
    }
}

 感觉代码写的还是太丑了

LeetCode刷题记录_有效的括号

标签:char   包括   sha   tac   else   put   boolean   nta   code   

原文地址:https://www.cnblogs.com/annofyf/p/9382547.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!