2021-09-18:给定一个只包括 ‘(‘,‘)‘,‘{‘,‘}‘,‘[‘,‘]‘ 的字符串 s ,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合
Posted 福大大架构师每日一题
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2021-09-18:给定一个只包括 ‘(‘,‘)‘,‘{‘,‘}‘,‘[‘,‘]‘ 的字符串 s ,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合相关的知识,希望对你有一定的参考价值。
2021-09-18:给定一个只包括 ‘(’,’)’,’{’,’}’,’[’,’]’ 的字符串 s ,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。
福大大 答案2021-09-18:
栈。遍历字符串,遇到左括号,入栈;遇到右括号,出栈。如果中途栈的元素个数小于0;或者遍历完成,栈还有元素;或者元素不匹配,就返回false,否则返回true。
代码用golang编写。代码如下:
package main
import "fmt"
func main() {
ret := isValid("{[]()}")
fmt.Println(ret)
}
func isValid(s string) bool {
if len(s) == 0 {
return true
}
str := []byte(s)
N := len(str)
stack := make([]byte, N)
size := 0
for i := 0; i < N; i++ {
cha := str[i]
if cha == '(' || cha == '[' || cha == '{' {
stack[size] = twoSelectOne(cha == '(', ')', (twoSelectOne(cha == '[', ']', '}')))
size++
} else {
if size == 0 {
return false
}
size--
last := stack[size]
if cha != last {
return false
}
}
}
return size == 0
}
func twoSelectOne(c bool, a byte, b byte) byte {
if c {
return a
} else {
return b
}
}
执行结果如下:
以上是关于2021-09-18:给定一个只包括 ‘(‘,‘)‘,‘{‘,‘}‘,‘[‘,‘]‘ 的字符串 s ,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合的主要内容,如果未能解决你的问题,请参考以下文章
2021-10-17:逆波兰表达式求值。根据 逆波兰表示法,求表达式的值。有效的算符包括 +-*/ 。每个运算对象可以是整数,也可以是另一个逆波兰表达式。说明:整数除法只保留整数部分。给定逆波兰(代码