每日一题---20. 有效的括号[力扣][Go]

简介: 每日一题---20. 有效的括号[力扣][Go]

题目描述

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

有效字符串需满足:

左括号必须用相同类型的右括号闭合。

左括号必须以正确的顺序闭合。

解题代码

// 利用栈的特性
func isValid(s string) bool {
  // 利用切片来模拟栈
  var s1 []string
  for _, s2 := range s {
    n := len(s1)
    if n >= 1 {
      if (s1[n - 1] == "{" && string(s2) == "}") || (s1[n - 1] == "[" && string(s2) == "]") || (s1[n - 1] == "(" && string(s2) == ")"){
        if n == 1 {
          s1 = nil
        } else {
          s1 = s1[:n - 1]
        }
      } else {
        s1 = append(s1,string(s2))
      }
      continue
    }
    s1 = append(s1,string(s2))
  }
  if len(s1) == 0 {
    return true
  } else {
    return false
  }
}

提交结果


相关文章
|
1月前
|
Go C++
【力扣】2696. 删除子串后的字符串最小长度(模拟 栈 C++ Go实现栈)
【2月更文挑战第18天】2696. 删除子串后的字符串最小长度(模拟 栈 C++ Go实现栈)
40 6
|
1月前
|
存储 C语言 索引
环形链表、环形链表 II、有效的括号​​​​​​​【LeetCode刷题日志】
环形链表、环形链表 II、有效的括号​​​​​​​【LeetCode刷题日志】
|
1月前
leetcode-301:删除无效的括号
leetcode-301:删除无效的括号
28 0
|
25天前
|
算法 Java C语言
【经典算法】LeetCode 20:有效的括号(Java/C/Python3实现含注释说明,Easy)
【经典算法】LeetCode 20:有效的括号(Java/C/Python3实现含注释说明,Easy)
17 1
|
17天前
|
算法
【经典LeetCode算法题目专栏分类】【第11期】递归问题:字母大小写全排列、括号生成
【经典LeetCode算法题目专栏分类】【第11期】递归问题:字母大小写全排列、括号生成
|
17天前
|
算法
【经典LeetCode算法题目专栏分类】【第9期】深度优先搜索DFS与并查集:括号生成、岛屿问题、扫雷游戏
【经典LeetCode算法题目专栏分类】【第9期】深度优先搜索DFS与并查集:括号生成、岛屿问题、扫雷游戏
|
21天前
|
SQL 算法 数据可视化
LeetCode 题目 32:最长有效括号【python】
LeetCode 题目 32:最长有效括号【python】
|
21天前
|
存储 SQL 算法
LeetCode第22题:生成括号【22/1000 python 递归|动态规划】
LeetCode第22题:生成括号【22/1000 python 递归|动态规划】
|
21天前
|
SQL 算法 数据挖掘
探索有效括号 力扣第20题:从栈到递归的多角度解法 【含图解 python】
探索有效括号 力扣第20题:从栈到递归的多角度解法 【含图解 python】
LeetCode | 20. 有效的括号
LeetCode | 20. 有效的括号