博客
关于我
有效括号算法题(Golang实现)
阅读量:437 次
发布时间:2019-03-06

本文共 1257 字,大约阅读时间需要 4 分钟。

为了判断给定字符串是否有效括号字符串,我们可以使用栈数据结构来模拟括号匹配过程。以下是详细的步骤:

  • 初始化栈和映射关系:创建一个空栈来存储左括号,并创建一个字典来映射右括号到对应的左括号。

  • 处理空字符串:如果输入字符串为空,直接返回true。

  • 检查字符串长度:如果字符串长度为奇数,返回false,因为无法完全匹配。

  • 遍历字符串

    • 遇到左括号({、[、(),将其压入栈。
    • 遇到右括号(}、]、)),检查栈是否为空。如果为空,返回false。
    • 检查栈顶是否是对应的左括号。如果是,弹出栈;否则,返回false。
  • 最终检查栈:遍历结束后,若栈为空,返回true,否则返回false。

  • 以下是用Golang实现的有效括号算法:

    package mainimport "fmt"func isValid(s string) bool {    stack := []byte{}    my_dick := map[byte]byte{        ']': '[',        '}': '{',        ')': '(',    }    s_len := len(s)    if s_len == 0 {        return true    }    if s_len % 2 != 0 {        return false    }    for i := 0; i < s_len; i++ {        char := s[i]        if char == '[' || char == '{' || char == '(' {            stack = append(stack, char)        } else {            if len(stack) == 0 {                return false            }            last := stack[len(stack)-1]            if my_dick[char] == last {                stack = stack[:len(stack)-1]            } else {                return false            }        }    }    return len(stack) == 0}func main() {    result := isValid("{[}}")    fmt.Println(result)}

    解释

    • 初始化栈和映射stack 用于存储左括号,my_dick 用于将右括号映射到对应的左括号。
    • 空字符串和奇数长度检查:直接返回结果。
    • 遍历字符:根据字符类型决定是否入栈或出栈,并检查匹配情况。
    • 最终检查:确保所有括号都匹配,栈为空则有效。

    通过这种方法,我们可以高效且准确地判断括号字符串的有效性。

    转载地址:http://dusuz.baihongyu.com/

    你可能感兴趣的文章
    npm的安装和更新---npm工作笔记002
    查看>>
    npm的常用操作---npm工作笔记003
    查看>>
    npm的常用配置项---npm工作笔记004
    查看>>
    npm的问题:config global `--global`, `--local` are deprecated. Use `--location=global` instead 的解决办法
    查看>>
    npm编译报错You may need an additional loader to handle the result of these loaders
    查看>>
    npm设置淘宝镜像、升级等
    查看>>
    npm设置源地址,npm官方地址
    查看>>
    npm设置镜像如淘宝:http://npm.taobao.org/
    查看>>
    npm配置安装最新淘宝镜像,旧镜像会errror
    查看>>
    NPM酷库052:sax,按流解析XML
    查看>>
    npm错误 gyp错误 vs版本不对 msvs_version不兼容
    查看>>
    npm错误Error: Cannot find module ‘postcss-loader‘
    查看>>
    npm,yarn,cnpm 的区别
    查看>>
    NPOI
    查看>>
    NPOI之Excel——合并单元格、设置样式、输入公式
    查看>>
    NPOI初级教程
    查看>>
    NPOI利用多任务模式分批写入多个Excel
    查看>>
    NPOI在Excel中插入图片
    查看>>
    NPOI将某个程序段耗时插入Excel
    查看>>
    NPOI格式设置
    查看>>