问题描述:

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

有效字符串需满足:

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

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

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

示例 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;
}
};

执行结果:

最新文章

  1. How to add taxonomy element to a summary view?
  2. Java开发中经典的小实例-(打印输入重复的值)
  3. 加jdk语句
  4. php null o false &#39;&#39;
  5. Nginx学习笔记(七) 创建子进程
  6. ios提示框,自动消失
  7. Cocos2d-x 3.0 动作
  8. 优化C++程序编译效率的一些方法
  9. CMDB, 配置管理数据库, ITIL - ManageEngine ServiceDesk Plus
  10. QT小记之在VS2005中使用(设置QMAKESPEC环境变量,以及编译QT Lib)
  11. noscript 标签,一个被忽视的重要标签
  12. 网页布局之flex
  13. react --- 搭建环境
  14. load data导txt文件进mysql中的数据
  15. linux查看日志文件命令
  16. JS实现控制HTML5背景音乐播放暂停
  17. Math.random()和UUID.randomUUID().toString()性能对比【纯原】
  18. 解决jpgraph在php7.0版本下时,无法显示例子图表的问题
  19. sqlserver window身份验证时切换账户的快捷键
  20. Memento 备忘录 快照模式 MD

热门文章

  1. 使用Nginx后如何在web应用中获取用户ip及原理解释
  2. CustomizaitonSpec Clone_VM
  3. shell 比较运算符
  4. 封装 oschina.net 表情选择
  5. Codeforces 366C Dima and Salad:背包dp
  6. BZOJ 3391 [Usaco2004 Dec]Tree Cutting网络破坏:dfs【无根树 节点分枝子树大小】
  7. Eclipse 下配置MySql5.6的连接池,使用Tomcat7.0
  8. 一种解决 MacBook 里的 App Store 无法登录的问题
  9. 【leetcode刷题笔记】Path Sum
  10. 洛谷 P4547 &amp; bzoj 5006 随机二分图 —— 状压DP+期望