()的ASCII值为 40 41 两者之间相差为1
{} []的ASCII值分别为 91 93 123 125 两者之间相差为2
leetcode 题目 有效的括号
给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。
示例 1:
输入: "()"
输出: true
示例 2:
输入: "()[]{}"
输出: true
示例 3:
输入: "(]"
输出: false
func isValid(s string) bool {
size := len(s)
stack := make([]byte,size)
top := 0
for i:= 0;i<size;i++{
b := s[i]
switch b{
case '(':
stack[top] = b + 1
top ++
case '{','[':
stack[top] = b + 2
top ++
case ']','}',')':
if top > 0 && stack[top-1] == b{
top = top - 1
}else{
return false
}
default :
return false
}
}
return top == 0
}