有效的括号golang实现(代码片段)

timliudream timliudream     2023-01-20     227

关键词:

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

有效字符串需满足:

  1. 左括号必须用相同类型的右括号闭合。
  2. 左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。
输入: "()"
输出: true
输入: "()[]"
输出: true
输入: "(]"
输出: false
输入: "([)]"
输出: false
输入: "[]"
输出: true
首先理解题意:
  1. 首先空字符串必定为true
  2. 其次括号成对出现
  3. 有可能在括号中间出现成对的括号

那我们就可以想象有一个容器,一直把字符串的每个字符塞进去,当成对出现的时候就去除,当容器内没有任何元素了,那就说明字符串是有效的括号组合,否则不是

    //特殊情况,空字符串返回true
    if len(s) == 0 
        return true
    

    //配对字典
    m := map[string]string")": "(", "]": "[", "": ""
    //
    var stack []string
    //把字符串的每个字符放进栈中,每放一个就判断与前一个是不是配对的
    for i := 0; i < len(s); i++ 
        if len(stack) == 0 
            stack = append(stack, string(s[i]))
         else 
            //判断是否配对
            //如果是相同的话,那就去除栈的最后一个元素
            //如果不相同的话,那就把源字符串的对应元素加进栈中
            if stack[len(stack)-1] == m[string(s[i])] 
                stack = stack[:len(stack)-1]
             else 
                stack = append(stack, string(s[i]))
            
        
    
    //判断栈中是否没有元素
    //是的话返回true
    //否则返回false
    if len(stack) == 0 
        return true
     else 
        return false
    

这里有个小技巧,就是每次我们放进容器的字符,当配对成功的时候,肯定是塞进右边的符号,所以可以构造一个以右边括号为key,左边括号为值得字典

有效的括号(leetcode20)(代码片段)

...’,‘[’,‘]’的字符串s,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。 查看详情

c#使用栈实现有效的括号(代码片段)

...‘,‘‘,‘[‘,‘]‘ 的字符串,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。注意空字符串可被认为是有效字符串。代码如下:publicstaticboolIsValiad(string... 查看详情

求有效的括号(代码片段)

文章目录求有效的括号1.题目描述2.题目链接3.解题思路求有效的括号1.题目描述2.题目链接力扣3.解题思路运用栈来实现,如果为字符为三个括号中的左括号,他们的右括号入栈,以此类推!classSolutionpublic 查看详情

leetcode实现20有效的括号,739每日的温度(代码片段)

...习目标:栈与实现掌握栈的实现,完成leetCode20题有效的括号739.每日的温度学习内容:1、数组实现栈2、链表实现栈3、完成20题有效的括号4、739.每日的温度题目:1、有效的括号:给定一个只包括(,),,,[,]的字符... 查看详情

stack类的应用(判断有效的括号)(代码片段)

...‘,‘‘,‘[‘,‘]‘ 的字符串,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。注意空字符串可被认为是有效字符串。输入:"()[]"输出:true输入:"([)]"输出:fa... 查看详情

leetcode第20题——有效的括号(代码片段)

...’,’[’,’]’的字符串s,判断字符串是否有效。有效字符串需满足:1、左括号必须用相同类型的右括 查看详情

第78题给定一个括号序列,判断是否是一个有效的括号序列(代码片段)

...包含\'(\',\')\',\'\',\'\',\'[\',\']\'这些字符,判断字符串是否有效。有效字符串需满足:  (1)(1)(1)左括号必须用相同类型的右括号闭合。   查看详情

力扣刷题:括号生成(java实现)(代码片段)

...f0c;请你设计一个函数,用于能够生成所有可能的并且有效的括号组合。有效括号组合需满足:左括号必须以正确的顺序闭合。示例1:输入:n=3输出:["((()))","(()())","(())()","()(())"," 查看详情

有效的括号(leetcode20)(代码片段)

...’,‘[’,‘]’的字符串s,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。每个右括号都有一个对应的相同类型的左括号。示例1:输入:... 查看详情

括号生成(java实现)(代码片段)

...对数,请你写出一个函数,使其能够生成所有可能的并且有效的括号组合。例如,给出 n=3,生成结果为:["((()))","(()())","(())()","()(())","()()()"]看到这个题,是合格的括号,有n个左括号就有n个右括号,那通过回溯法可以解决。... 查看详情

有效的括号(代码片段)

目录有效的括号题解有效的括号给定一个只包括‘(‘,‘)‘,‘‘,‘‘,‘[‘,‘]‘?的字符串,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。注意空字符... 查看详情

2021-09-19:数字n代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且有效的括号组合。(代码片段)

...f0c;请你设计一个函数,用于能够生成所有可能的并且有效的括号组合。福大大答案2021-09-19:递归。参数1:左括号-右括号的数量。参数2:左括号剩多少。代码用golang编写。代码如下:packagemainimport"fmt"fun... 查看详情

用自定义链式栈解决力扣括号匹配问题(代码片段)

...测试一、背景在力扣题库中有一道经典的栈表应用问题:有效的括号给定一个只包括‘(‘,‘)‘,‘‘,‘‘,‘[‘,‘]‘的字符串,判断字符串是否有效。有效字符串需满足:1、左括号必须用相同类型的右括号闭合。2、左... 查看详情

code皮皮虾双栈+贪心思路讲解代码实现——>有效的括号字符串(代码片段)

文章目录😉毛遂自荐✨题目🌝解题双栈思路代码实现贪心思路代码实现💖最后Code皮皮虾一个沙雕而又有趣的憨憨少年,和大多数小伙伴们一样喜欢听歌、游戏,当然除此之外还有写作的兴趣,emm…,... 查看详情

java有效的括号(代码片段)

查看详情

有效的括号.(代码片段)

...‘,‘‘,‘[‘,‘]‘ 的字符串,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。注意空字符串可被认为是有效字符串。示例1:输入:"()"输出:true示例 2:... 查看详情

20.有效的括号(代码片段)

...‘,‘‘,‘[‘,‘]‘ 的字符串,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。注意空字符串可被认为是有效字符串。1//方法一:使用栈,成对出现则弹... 查看详情

golang242.有效的字母异位词(代码片段)

查看详情