美文网首页
20. 有效的括号

20. 有效的括号

作者: 王侦 | 来源:发表于2022-10-03 14:40 被阅读0次

题目地址(20. 有效的括号)

https://leetcode.cn/problems/valid-parentheses/

题目描述

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

有效字符串需满足:

左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
每个右括号都有一个对应的相同类型的左括号。

前置知识

公司

思路

  • 对于最近相关性题目,一般首先考虑使用栈

关键点

  • Go的栈,这里使用切片实现
  • 特别注意else if len(stack) > 0 && stack[len(stack) - 1] == s[i]中第一个条件

代码

  • 语言支持:Go

Go Code:


func isValid(s string) bool {
    if len(s) % 2 == 1 {
        return false
    }
    n := len(s)
    stack := make([]byte, 0)

    for i := 0; i < n; i++ {
        if s[i] == '(' {
            stack = append(stack, ')')
        } else if s[i] == '[' {
            stack = append(stack, ']')
        } else if s[i] == '{' {
            stack = append(stack, '}')
        } else if len(stack) > 0 && stack[len(stack) - 1] == s[i] {
            stack = stack[:len(stack) - 1]
        } else {
            return false
        }
    }
    return len(stack) == 0
}

复杂度分析

令 n 为数组长度。

  • 时间复杂度:O(n)
  • 空间复杂度:O(n)

相关文章

网友评论

      本文标题:20. 有效的括号

      本文链接:https://www.haomeiwen.com/subject/aqreartx.html