码迷,mamicode.com
首页 > 其他好文 > 详细

20. 有效的括号

时间:2020-04-02 00:55:31      阅读:71      评论:0      收藏:0      [点我收藏+]

标签:str   必须   nbsp   app   mys   返回   turn   class   val   

给定一个只包括 ‘(‘,‘)‘,‘{‘,‘}‘,‘[‘,‘]‘ 的字符串,判断字符串是否有效。

有效字符串需满足:
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. 有效的括号

标签:str   必须   nbsp   app   mys   返回   turn   class   val   

原文地址:https://www.cnblogs.com/qijian1992/p/12616976.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!