20. 有效的括号
Posted qijian1992
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了20. 有效的括号相关的知识,希望对你有一定的参考价值。
给定一个只包括 ‘(‘,‘)‘,‘{‘,‘}‘,‘[‘,‘]‘ 的字符串,判断字符串是否有效。
有效字符串需满足:
1.左括号必须用相同类型的右括号闭合。
2.左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。
示例 1:
输入: "()"
输出: true
示例 2:
输入: "()[]{}"
输出: true
示例 3:
输入: "(]"
输出: false
示例 4:
输入: "([)]"
输出: false
示例 5:
输入: "{[]}"
输出: true
菜解:
func isValid(s string) bool { mySlice := make([]byte,len(s)) for i := 0; i < len(s); i++ { if (s[i] == ‘(‘) || (s[i] == ‘{‘) || (s[i] == ‘[‘) { mySlice = append(mySlice,s[i]) } if s[i] == ‘)‘ { if mySlice[len(mySlice)-1] == ‘(‘ { mySlice = mySlice[:len(mySlice)-1] } else if (mySlice[len(mySlice)-1] == ‘)‘) || (mySlice[len(mySlice)-1] == ‘}‘) || (mySlice[len(mySlice)-1] == ‘]‘) { mySlice = append(mySlice,s[i]) } else { return false } } if s[i] == ‘}‘ { if mySlice[len(mySlice)-1] == ‘{‘ { mySlice = mySlice[:len(mySlice)-1] } else if (mySlice[len(mySlice)-1] == ‘)‘) || (mySlice[len(mySlice)-1] == ‘}‘) || (mySlice[len(mySlice)-1] == ‘]‘) { mySlice = append(mySlice,s[i]) } else { return false } } if s[i] == ‘]‘ { if mySlice[len(mySlice)-1] == ‘[‘ { mySlice = mySlice[:len(mySlice)-1] } else if (mySlice[len(mySlice)-1] == ‘)‘) || (mySlice[len(mySlice)-1] == ‘}‘) || (mySlice[len(mySlice)-1] == ‘]‘) { mySlice = append(mySlice,s[i]) } else { return false } } } return true }
优解:
func isValid(s string) bool { // 空字符串直接返回 true if len(s) == 0 { return true } stack := make([]rune, 0) for _, v := range s { if (v == ‘[‘) || (v == ‘(‘) || (v == ‘{‘) { stack = append(stack, v) } else if ((v == ‘]‘) && len(stack) > 0 && stack[len(stack)-1] == ‘[‘) || ((v == ‘)‘) && len(stack) > 0 && stack[len(stack)-1] == ‘(‘) || ((v == ‘}‘) && len(stack) > 0 && stack[len(stack)-1] == ‘{‘) { stack = stack[:len(stack)-1] } else { return false } } return len(stack) == 0 }
以上是关于20. 有效的括号的主要内容,如果未能解决你的问题,请参考以下文章
代码随想录算法训练营第11天 | ● 20. 有效的括号 ● 1047. 删除字符串中的所有相邻重复项 ● 150. 逆波兰表达式求值