难度: Easy
原题连接
内容描述
Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the input string is valid.
An input string is valid if:
Open brackets must be closed by the same type of brackets.
Open brackets must be closed in the correct order.
Note that an empty string is also considered valid.
Input: "()"
Output: true
Input: "()[]{}"
Output: true
Input: "(]"
Output: false
Input: "([)]"
Output: false
Input: "{[]}"
Output: true
思路 1 - 时间复杂度: O(N)- 空间复杂度: O(N)******
代码:
/**
* @param {string} s
* @return {boolean}
*/
var isValid = function(s) {
if(!s){
return true;
}
let array = [];
for(let i = 0,len = s.length; i<len; i++){
let cur = s.charAt(i);
if(cur === '(' || cur === '{' || cur === '['){
array.push(cur);
}else if(!array.length){
return false;
}else{
let pre = array.pop();
if(pre === '(' && cur !== ')'){
return false;
}
if(pre === '{' && cur !== '}'){
return false;
}
if(pre === '[' && cur !== ']'){
return false;
}
}
}
return !array.length
};