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

    你可能感兴趣的文章
    OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
    查看>>
    OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
    查看>>
    OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
    查看>>
    OAuth2.0_授权服务配置_三项内容_Spring Security OAuth2.0认证授权---springcloud工作笔记141
    查看>>
    OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
    查看>>
    OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
    查看>>
    OAuth2.0_授权服务配置_密码模式及其他模式_Spring Security OAuth2.0认证授权---springcloud工作笔记145
    查看>>
    OAuth2.0_授权服务配置_授权码模式_Spring Security OAuth2.0认证授权---springcloud工作笔记144
    查看>>
    OAuth2.0_授权服务配置_资源服务测试_Spring Security OAuth2.0认证授权---springcloud工作笔记146
    查看>>
    OAuth2.0_环境介绍_授权服务和资源服务_Spring Security OAuth2.0认证授权---springcloud工作笔记138
    查看>>
    OAuth2.0_环境搭建_Spring Security OAuth2.0认证授权---springcloud工作笔记139
    查看>>
    oauth2.0协议介绍,核心概念和角色,工作流程,概念和用途
    查看>>
    OAuth2.0四种模式的详解
    查看>>
    OAuth2授权码模式详细流程(一)——站在OAuth2设计者的角度来理解code
    查看>>
    oauth2登录认证之SpringSecurity源码分析
    查看>>
    OAuth2:项目演示-模拟微信授权登录京东
    查看>>
    OA系统多少钱?OA办公系统中的价格选型
    查看>>
    OA系统选型:选择好的工作流引擎
    查看>>
    OA让企业业务流程管理科学有“据”
    查看>>
    OA项目之会议通知(查询&是否参会&反馈详情)
    查看>>