标签: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
}
标签:str 必须 nbsp app mys 返回 turn class val
原文地址:https://www.cnblogs.com/qijian1992/p/12616976.html