【LeetCode-字符串】有效的括号
时间:2020-04-11
本文章向大家介绍【LeetCode-字符串】有效的括号,主要包括【LeetCode-字符串】有效的括号使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
题目描述
给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。
有效字符串需满足:
- 左括号必须用相同类型的右括号闭合。
- 左括号必须以正确的顺序闭合。
- 注意空字符串可被认为是有效字符串。
示例:
输入: "()"
输出: true
输入: "(]"
输出: false
输入: "{[]}"
输出: true
题目链接: https://leetcode-cn.com/problems/valid-parentheses/
思路
用栈来做。遍历输入的字符串序列,当当前元素为右括号(')',']','}')并且栈顶元素为当前元素对应的左括号('(','[','{')时,将栈顶元素弹出;当不对应或者栈为空时,将当前元素压入栈。遍历结束时,如果栈为空,则说明括号匹配,字符串有效;否则说明字符串无效。代码如下:
class Solution {
public:
bool isValid(string s) {
if(s.empty()){
return true;
}
if(s[0]==')' || s[0]==']' || s[0]=='}'){
return false;
}
stack<char> stk;
stk.push(s[0]);
for(int i=1; i<s.length(); i++){
if(stk.empty()){ // 别忘了这一步
stk.push(s[i]);
}else if(s[i]==')'){
if(stk.top()=='('){
stk.pop();
}else{
stk.push(s[i]);
}
}else if(s[i]==']'){
if(stk.top()=='['){
stk.pop();
}else{
stk.push(s[i]);
}
}else if(s[i]=='}'){
if(stk.top()=='{'){
stk.pop();
}else{
stk.push(s[i]);
}
}else{
stk.push(s[i]);
}
}
if(stk.empty()){
return true;
}else return false;
}
};
- 时间复杂度:O(n)
- 空间复杂度:O(n)
当括号完全不匹配时,栈的空间为字符串的长度。
原文地址:https://www.cnblogs.com/flix/p/12681257.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法