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. 有效的括号的主要内容,如果未能解决你的问题,请参考以下文章

leetcode20有效的括号

LeetCode 20. 有效的括号

leetcode-----20. 有效的括号

LeetCode第20题——有效的括号

代码随想录算法训练营第11天 | ● 20. 有效的括号 ● 1047. 删除字符串中的所有相邻重复项 ● 150. 逆波兰表达式求值

Java算法 每日一题 编号20:有效的括号