博客
关于我
LeetCode刷题(6)--有效的括号
阅读量:143 次
发布时间:2019-02-26

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

题目描述

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

有效字符串需满足:

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

左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。

示例:

输入: “()”
输出: true

输入: “()[]{}”

输出: true

输入: “([)]”

输出: false

输入: “{[]}”

输出: true

解题思路

首先,因为括号是成对出现的,所以,字符串的长度必须是2的倍数,如果不是直接return false。

其次,如果字符串为空,直接return true。
使用栈这种数据结构进行实现是比较方便的。

bool EffectiveBrackets(string s){	if(s.empty())		return true;	if(s.length()%2!=0)		return false;	stack
st; for(int i=0;i

结果:

在这里插入图片描述
分析:
1.先判断字符串是否为空,若为空,则直接返回true。
2.判断字符串是否是2的倍数,如果不是,则返回false。
3.遍历字符串,如果字符为’(’,则在栈顶增加’)’,如果字符为’{’,则在栈顶增加’}’,如果字符为’[’,则在栈顶增加’]’。
4.如果栈顶为空,或者栈顶元素不是我们匹配的元素,则返回false。
5.遍历完成,出栈。

演示b过程

()[]{}
当i=0时,s[0]=’(’,入栈’)’
当i=1时,s[1]=’)’,st.top()=’)’,不为空且st.top()=s[1],出栈
当i=2时,s[2]=’[’,入栈’]’
当i=3时,s[3]=’]’,st.top()=’]’,不为空且st.top()=s[3],出栈
当i=4时,s[4]=’{’,入栈’}’
当i=5时,s[5]=’}’,st.top()=’}’,不为空且st.top()=s[5],出栈,结束。

演示c过程

([)]
当i=0时,s[0]=’(’,入栈’)’
当i=1时,s[1]=’[’,入栈’]’
当i=2时,s[2]=’)’,st.top()=’]’,不为空但st.top()!=s[2],return false

演示d过程

{[]}
当i=0时,s[0]=’{’,入栈’}’
当i=1时,s[1]=’[’,入栈’]’
当i=2时,s[2]=’]’,st.top()=’]’,不为空且st.top()=s[2],st.pop(),出栈。
当i=3时,s[3]=’}’,st.top()=’}’,不为空且st.top()=s[3],st.pop(),出栈,结束。
在这里插入图片描述

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

你可能感兴趣的文章
MySQL 数据类型和属性
查看>>
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询数据库所有表的字段信息
查看>>
【Java基础】什么是面向对象?
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>