分类:栈与递归
题目描述
给定一个只包括 '('
,')'
,'{'
,'}'
,'['
,']'
的字符串 s
,判断字符串是否有效。
有效字符串需满足:
- 左括号必须用相同类型的右括号闭合。
- 左括号必须以正确的顺序闭合。
提示:
1 <= s.length <= 104
s
仅由括号'()[]{}'
组成
示例 1:
输入:s = "()[]{}"
输出:true
示例 2:
输入:s = "([)]"
输出:false
示例 3:
输入:s = "{[]}"
输出:true
思路:
使用栈,碰到左括号时入栈,碰到右括号时弹出栈顶元素与之匹配,若匹配不上则返回false
代码实现:
/**
* @param {string} s
* @return {boolean}
*/
var isValid = (s) => {
const map = { "{": "}", "(": ")", "[": "]" }
const stack = []
for (let i = 0; i < s.length; i++) {
const cur = s[i]
if (map[cur]) {
stack.push(cur)
} else {
if (stack.length === 0) {
return false
}
const stackTop = stack.pop()
if (map[stackTop] !== cur) {
return false
}
}
}
return stack.length === 0
}
运行结果: