Leetcode20 (有效的括号)

题目描述

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

有效字符串需满足:

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

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

每个右括号都有一个对应的相同类型的左括号。

示例 1:

输入:s = "()"

输出:true

示例 2:

输入:s = "()[]{}"

输出:true

示例 3:

输入:s = "(]"

输出:false

示例 4:

输入:s = "([])"

输出:true

提示:

1 <= s.length <= 104

s 仅由括号 '()[]{}' 组成

题解1

相当经典的一道题

就是用栈

遍历s,当前为左括号时,直接入栈

当前为右括号判断栈顶元素是否为对应左括号

小点:

1、可以直接判断s长度,如果为奇数直接返回false

2、需要判断时,栈顶元素为空,直接返回false

代码:

sql 复制代码
class Solution {
    public boolean isValid(String s) {
        if(s.length()%2==1) return false;
        Deque<Character> stack =new ArrayDeque<>();
        Map<Character,Character> map=new HashMap<>();
        map.put(')','(');
        map.put(']','[');
        map.put('}','{');
        int len=s.length();
        for(int i=0;i<len;i++){
            char ch=s.charAt(i);
            if(map.containsKey(ch)){
                if(stack.isEmpty()||map.get(ch)!=stack.peek()) return false;
                stack.pop();
            }
            elsestack.push(ch);
        }
       return stack.isEmpty();
    }
}

题解2

看了一眼最优解

发现可以用数组模拟栈

并且用s.toCharArray()作为这个栈

可以实现栈的同时在这个数组上读取数据

性能极好

sql 复制代码
class Solution {
    public boolean isValid(String s) {
        int len=s.length();
        if(len%2==1) return false;
        char[] stack = s.toCharArray();
        int i=0,j=0;
        while(i<len){
            if(stack[i]==')'&&j>0&&stack[j-1]=='(') j--;
            else if(stack[i]==']'&&j>0&&stack[j-1]=='[') j--;
            else if(stack[i]=='}'&&j>0&&stack[j-1]=='{') j--;
            else stack[j++]=stack[i];
            i++;
        }
        return j==0;
    }
}
相关推荐
一行代码一行诗++14 小时前
for循环中的break和continue
数据结构·算法
AI人工智能+电脑小能手14 小时前
【大白话说Java面试题 第67题】【JVM篇】第27题:生产环境服务器变慢,诊断思路和性能评估谈谈?
java·服务器·jvm·面试
Tisfy14 小时前
LeetCode 3043.最长公共前缀的长度:哈希表(不转string)
算法·leetcode·散列表·题解·哈希表
代码中介商14 小时前
排序算法完全指南(三):插入排序深度详解
算法·排序算法
半夜修仙14 小时前
Redis中Set数据类型的常见命令
java·数据库·redis·笔记·学习
SuniaWang14 小时前
AgentX 专栏-00前言:一个Java开发者的Agent实践之路
java·人工智能·spring boot·langchain·系统架构
承渊政道14 小时前
【贪心算法】(经典实战应用解析(六):整数替换、俄罗斯套娃信封问题、可被三整除的最⼤和、距离相等的条形码、重构字符串)
c++·算法·leetcode·贪心算法·排序算法·动态规划·哈希算法
诸葛老刘14 小时前
国密python调java服务
java·python·国密·sm2
宠..14 小时前
VS Code SSH 远程连接 Ubuntu 并实现快速运行(C/C++示例)
java·运维·c语言·开发语言·c++·ubuntu·ssh
WL_Aurora14 小时前
Python 算法基础篇之排序算法(二):希尔、快速、归并
python·算法·排序算法