leetcode第四天 : 有效的括号

有效的括号

题目描述

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

有效字符串需满足:

  1. 左括号必须用相同类型的右括号闭合

  2. 左括号必须以正确的顺序闭合。

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

示例 1:

输入: "()"
输出: true

示例 2:

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

示例 3:

输入: "(]"
输出: false

示例 4:

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

示例 5:

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

思路

① 首先确定输入的字符串必定为空串或者是括号串

② 如果遇到空串直接返回true, 否则如果第一个括号是右单边括号, 直接返回false

③ 根据题意, 符合要求的括号串, 必定是成对出现, 否则不满足题意, 示例4是一种非常特殊的情况, 因为它虽然看起来是两对括号匹配的, 实际上在'[)'中已经被判为false, 违反了第二条规则

④ 把所有的左单边括号放在栈中, 如果遇到右单边括号, 则需弹出栈顶的左单边括号进行判断

⑤ 正确的顺序是指每次遇到右单边括号时, 都要与栈顶的左单边括号相匹配

⑥ 编程实现

例子

假设括号串为{}()({[]})

有效的括号.png

编程

import java.util.Stack;

/**
 * @author Jack
 * @date 2019-06-16-18:43
 */
public class Solution {

    public static boolean isValid(String s) {
        //切割字符串, 分成一个个单边括号
        String[] split = s.split("");
        Stack stack = new Stack();
        for (int i = 0;i <= split.length -1; i++){
            //判断是否为左边括号
            if(split[i].equals("{")||split[i].equals("[")||split[i].equals("(")){
                stack.push(split[i]);
                continue;
            //第一个元素不是左单边括号
            }else if(i == 0){
                //如果为空串则返回真
                if ("".equals(split[0])){
                    return true;
                //右单边括号
                }else{
                    return false;
                }
            }else{
                //判断最后一个元素是右单边括号且栈为空时, 不符合规则, 示例 : "()]"
                if(i == split.length-1 && stack.empty() && (split[i].equals("}")||split[i].equals("]")||split[i].equals(")"))){
                    return false;
                }
                //取出栈顶元素进行判断
                if(!stack.empty()) {
                    String pop = (String) stack.pop();
                    switch (split[i]){
                        case "}":
                            if("{".equals(pop)){
                                //如果已经遍历到最后一个元素, 且匹配, 而且没有多余的左单边括号, 则返回true
                                if(i == split.length -1 && stack.empty()) {
                                    return true;
                                }
                                continue;
                            //与栈顶的左单边括号不匹配,返回false
                            }else{
                                return false;
                            }
                        case "]":
                            if("[".equals(pop)){
                                if(i == split.length -1 && stack.empty()){
                                    return true;
                                }
                                continue;
                            }else{
                                return false;
                            }
                        case ")":
                            if("(".equals(pop)){
                                if(i == split.length -1 && stack.empty()){
                                    return true;
                                }
                                continue;
                            }else{
                                return false;
                            }
                        default:
                            return false;
                    }
                }
            }
        }
        return false;
    }

    public static void main(String[] args) {
        System.out.println(isValid(""));
    }

}

总结

说实话, 效率不堪一击, 内存还看得过去, 不过我还是不太懂内存消耗的影响因素是什么, 哈哈哈哈, 感觉自己做出来了就很不错了......看了别人的题解, 感觉自己写的弱爆了, 下面给出别人的简单解法, 太简洁了

class Solution {
    public boolean isValid(String s) {
        char[] array = s.toCharArray();
        Stack<Character> stack = new Stack<>();
        for (char c : array) {
            if (c =='(' || c =='[' || c =='{') {
                stack.push(c);
            }else if(stack.isEmpty()){
                return false;
            }else if (c ==')' && stack.peek()=='(') {
                stack.pop();
            } else if (c ==']' && stack.peek()=='[') {
                stack.pop();
            } else if (c =='}' && stack.peek()=='{') {
                stack.pop();
            }else{
                return false;
            }
        }
        if(!stack.isEmpty()){
            return false;
        }
        return true;
        
    }
}

作者:vicyas
链接:https://leetcode-cn.com/problems/two-sum/solution/zui-pu-tong-de-jie-fa-by-vicyas/
来源:力扣(LeetCode)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,905评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,140评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,791评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,483评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,476评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,516评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,905评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,560评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,778评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,557评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,635评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,338评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,925评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,898评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,142评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,818评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,347评论 2 342