给定一个只包含三种字符的字符串:( ,) 和 *,写一个函数来检验这个字符串是否为有效字符串。有效字符串具有如下规则:
- 任何左括号
(必须有相应的右括号)。 - 任何右括号
)必须有相应的左括号(。 - 左括号
(必须在对应的右括号之前)。 *可以被视为单个右括号),或单个左括号(,或一个空字符串。- 一个空字符串也被视为有效字符串。
示例 1:
输入: "()"
输出: True
示例 2:
输入: "(*)"
输出: True
示例 3:
输入: "(*))"
输出: True
示例 4:
输入: "(((((()*)(*)*))())())(()())())))((**)))))(()())()"
输出: False
题解:
/**
* @param {string} s
* @return {boolean}
*/
var checkValidString = function (s) {
const stack = []
const helpStack = []
for (let i = 0; i < s.length; i++) {
// stack栈和helpStack栈存储当前位置下标
if (s[i] == '(') {
stack.push(i)
}
if (s[i] == '*') {
helpStack.push(i)
}
if (s[i] == ')') {
// 当遇到“)”时,如果stack栈为空,
// 判断辅助栈内是否为空 如果为空 返回false
// 如果helpStack内不为空 辅助栈出栈
if (!stack.length) {
if (!helpStack.length) return false
helpStack.pop()
}
// 如果stack栈不为空,栈顶出栈
stack.pop()
}
}
// 如果stack站长度大于helpStack栈 返回false
if (stack.length > helpStack.length) return false
// 如果stack栈和helpStack栈都不为空,遍历
// 当stack栈顶下标值大于helpStack栈顶下标时 返回false
while (stack.length && helpStack.length) {
if (stack.pop() > helpStack.pop()) return false
}
return true
};
来源:力扣(LeetCode)
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。