博客
关于我
有效括号算法题(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/

    你可能感兴趣的文章
    ntpdate 通过外网同步时间
    查看>>
    ntpdate同步配置文件调整详解
    查看>>
    NTPD使用/etc/ntp.conf配置时钟同步详解
    查看>>
    NTP及Chrony时间同步服务设置
    查看>>
    NTP服务器
    查看>>
    NTP配置
    查看>>
    NUC1077 Humble Numbers【数学计算+打表】
    查看>>
    NuGet Gallery 开源项目快速入门指南
    查看>>
    NuGet(微软.NET开发平台的软件包管理工具)在VisualStudio中的安装的使用
    查看>>
    nuget.org 无法加载源 https://api.nuget.org/v3/index.json 的服务索引
    查看>>
    Nuget~管理自己的包包
    查看>>
    NuGet学习笔记001---了解使用NuGet给net快速获取引用
    查看>>
    nullnullHuge Pages
    查看>>
    NullPointerException Cannot invoke setSkipOutputConversion(boolean) because functionToInvoke is null
    查看>>
    null可以转换成任意非基本类型(int/short/long/float/boolean/byte/double/char以外)
    查看>>
    Number Sequence(kmp算法)
    查看>>
    Numix Core 开源项目教程
    查看>>
    numpy
    查看>>
    Numpy 入门
    查看>>
    NumPy 库详细介绍-ChatGPT4o作答
    查看>>