LeetCode第20题:有效的括号
2024-09-29 11:10:55
问题描述:
给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。
示例 1:
输入: "()"
输出: true
示例 2:
输入: "()[]{}"
输出: true
示例 3:
输入: "(]"
输出: false
示例 4:
输入: "([)]"
输出: false
示例 5:
输入: "{[]}"
输出: true
解题思路:
这道题不是特别难,
如果字符串为空,返回true。
先初始化一个STL的stack,左括号入栈,右括号与栈顶进行匹配,匹配的话出栈,不匹配返回false。
如果当字符串结束之后栈仍然不为空,仍然需要返回false。
如果当字符串结束之后栈为空,则返回true。
C+代码:
class Solution {
public:
bool isValid(string s) {
//空字符串有效
if(s.size()==0)
return true;
//初始化堆栈来存储各个括号
std::stack<char> brackets;
for(int noOfStr=0;noOfStr<s.size();++noOfStr){
char tempChar=s[noOfStr];
switch(tempChar){
//栈不空且栈顶为相应的左括号,栈顶出栈
//否则返回false
case ')':{
if(!brackets.empty()&&brackets.top()=='(')
brackets.pop();
else
return false;
}break;
case ']':{
if(!brackets.empty()&&brackets.top()=='[')
brackets.pop();
else
return false;
}break;
case '}':{
if(!brackets.empty()&&brackets.top()=='{')
brackets.pop();
else
return false;
}break;
//左括号入栈
default:{
brackets.push(tempChar);
}
}
}
//字符串结束后栈仍不为空,返回false
if(!brackets.empty())
return false;
else
return true;
}
};
执行结果:
最新文章
- How to add taxonomy element to a summary view?
- Java开发中经典的小实例-(打印输入重复的值)
- 加jdk语句
- php null o false &#39;&#39;
- Nginx学习笔记(七) 创建子进程
- ios提示框,自动消失
- Cocos2d-x 3.0 动作
- 优化C++程序编译效率的一些方法
- CMDB, 配置管理数据库, ITIL - ManageEngine ServiceDesk Plus
- QT小记之在VS2005中使用(设置QMAKESPEC环境变量,以及编译QT Lib)
- noscript 标签,一个被忽视的重要标签
- 网页布局之flex
- react --- 搭建环境
- load data导txt文件进mysql中的数据
- linux查看日志文件命令
- JS实现控制HTML5背景音乐播放暂停
- Math.random()和UUID.randomUUID().toString()性能对比【纯原】
- 解决jpgraph在php7.0版本下时,无法显示例子图表的问题
- sqlserver window身份验证时切换账户的快捷键
- Memento 备忘录 快照模式 MD
热门文章
- 使用Nginx后如何在web应用中获取用户ip及原理解释
- CustomizaitonSpec Clone_VM
- shell 比较运算符
- 封装 oschina.net 表情选择
- Codeforces 366C Dima and Salad:背包dp
- BZOJ 3391 [Usaco2004 Dec]Tree Cutting网络破坏:dfs【无根树 节点分枝子树大小】
- Eclipse 下配置MySql5.6的连接池,使用Tomcat7.0
- 一种解决 MacBook 里的 App Store 无法登录的问题
- 【leetcode刷题笔记】Path Sum
- 洛谷 P4547 &; bzoj 5006 随机二分图 —— 状压DP+期望