博客
关于我
Leetcode20. 有效的括号 辅助栈
阅读量:527 次
发布时间:2019-03-07

本文共 991 字,大约阅读时间需要 3 分钟。

解题思路

我们可以用栈来解决这题,因为栈是先进后出,和这题的要求刚好一致,如果遇到左括号就直接入栈,遇到右括号,就判断栈顶的括号是否为该右括号相对应的左括号,如果不匹配就返回false,匹配就把栈顶元素弹出,然后开始下一个元素的判断;

这里有个小技巧,如何快速匹配左右括号?在java中能用HashMap,用key保存左括号,value保存右括号。

代码

class Solution {       Map
map = new HashMap<>() { //保存要匹配的左右括号,可以快速匹配 { put('(',')'); put('{','}'); put('[',']'); } }; public boolean isValid(String s) { Deque
stack = new LinkedList<>(); //用双端队列模拟战 for(char i : s.toCharArray()) { //把s转为char数组,然后遍历 if(map.containsKey(i)) //判断是不是左括号,是左括号就入栈 stack.push(i); //判断右括号是否和栈顶为匹配的左括号,匹配就直接弹出栈顶的左括号; //不匹配就直接返回false; 因为要弹出栈顶所以先要判断栈是否为空 else if(stack.isEmpty() || i != map.get(stack.pop())) return false; } return stack.isEmpty(); //栈空就代表完全匹配成功,返回true; //不为空就返回false,代表栈还有左括号; }}

复杂度分析

  • 时间复杂度 :O(N)
  • 空间复杂度 :O(N)

转载地址:http://yaynz.baihongyu.com/

你可能感兴趣的文章
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>
mysql中的rbs,SharePoint RBS:即使启用了RBS,内容数据库也在不断增长
查看>>
mysql中的undo log、redo log 、binlog大致概要
查看>>