java括号匹配算法求解(用栈实现)

Java括号匹配算法求解(用栈实现)

什么是括号匹配?

在计算机科学中,括号匹配是指验证一个表达式中的括号是否是成对出现、嵌套正确的。例如:()[]{}{}是一个合法的括号序列,而([)]则是不合法的括号序列。

如何检查括号匹配?

使用栈数据结构可以很容易地完成括号匹配的检查。 遍历字符串中的每个字符,如果遇到左括号则入栈,如果遇到右括号则出栈,出栈的同时判断是否与当前右括号匹配。如果栈为空,说明左右括号不匹配,如果最后栈不为空,也说明左右括号不匹配,否则左右括号匹配。

Java代码

public static boolean checkBracket(String s) {
    Stack<Character> stack = new Stack<>();
    for (int i = 0; i < s.length(); i++) {
        char ch = s.charAt(i);
        if (ch == '(' || ch == '[' || ch == '{') {//左括号入栈
            stack.push(ch);
        } else if (ch == ')' || ch == ']' || ch == '}') {//右括号出栈,判断和左括号是否匹配
            if (stack.isEmpty()) {
                return false;
            }
            char top = stack.pop();
            if (ch == ')' && top != '(') {
                return false;
            }
            if (ch == ']' && top != '[') {
                return false;
            }
            if (ch == '}' && top != '{') {
                return false;
            }
        }
    }
    return stack.isEmpty();//最后判断栈是否为空
}

示例说明

下面给出两个示例说明。

示例1

输入:()[{}][]

输出:true

解释:左右括号都匹配,合法括号序列。

示例2

输入:()[]{}}

输出:false

解释:左右括号不匹配,不合法括号序列。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:java括号匹配算法求解(用栈实现) - Python技术站

(0)
上一篇 2023年5月19日
下一篇 2023年5月19日

相关文章

  • Java之JsonArray用法讲解

    Java之JsonArray用法讲解 在Java中,经常需要使用Json格式的数据结构进行数据传递和交换。JsonArray是Json中的一个数据类型,本文将讲解JsonArray的用法。 JsonArray是什么? JsonArray是一个有序集合,其中包含了一系列的JsonElement。JsonElement是Json中的基本数据类型,可以是JsonA…

    Java 2023年5月26日
    00
  • Java实现带图形界面的聊天程序

    Java实现带图形界面的聊天程序攻略 1. 实现基础功能 要实现一个聊天程序,必须实现以下基础功能:- 用户注册和登录- 建立聊天连接- 发送和接收聊天信息- 断开聊天连接 在 Java 中,可以使用 Socket 通讯实现上述基础功能。Socket 提供了底层网络通讯的封装,可以方便地在网络上通讯,Java 中的 Socket 类提供了客户端和服务器端的功…

    Java 2023年5月26日
    00
  • Spring Security 单点登录简单示例详解

    首先,需要明确单点登录(Single Sign-On,SSO)是什么。它指的是用户只需要进行一次身份验证,就能在多个应用系统中使用其权限,而无需再次输入其凭证或重新进行身份验证。 Spring Security 是 Spring 家族中的安全框架,为 Web 应用提供了认证和授权方案,并支持单点登录。 下面,我们将详细讲解“Spring Security 单…

    Java 2023年5月20日
    00
  • 解决SpringBoot启动过后不能访问jsp页面的问题(超详细)

    解决SpringBoot启动过后不能访问jsp页面的问题(超详细) 问题描述 SpringBoot是一个高度集成化的框架,它不需要xml和配置文件即可构建Spring应用程序。然而,当我们在使用SpringBoot构建web应用程序的过程中,有时会遇到不能访问jsp页面的问题。这是因为SpringBoot默认使用thymeleaf作为模板引擎,而不是jsp。…

    Java 2023年6月15日
    00
  • Java三种移位运算符原理解析

    Java三种移位运算符原理解析 移位运算是基于二进制补码进行运算的。Java 中有三种移位运算符:左移运算符、右移运算符和无符号右移运算符。下面分别对这三种移位运算符进行详细讲解。 左移运算符(<<) 左移运算符将一个数的二进制表示向左移动指定的位数。其语法为: 左移位数 << 左移运算值 左移位数是一个整数,代表要进行左移的位数。左…

    Java 2023年5月26日
    00
  • 浅谈SpringMVC HandlerInterceptor诡异问题排查

    下面来详细讲解如何排查 SpringMVC HandlerInterceptor 的诡异问题。 1. 确定问题 当我们在 SpringMVC 中使用 HandlerInterceptor 的时候,发现执行顺序有问题,拦截器不按照我们希望的顺序执行,或者是某个拦截器失效了。这个时候,我们首先需要确定问题的根源。 1.1 确定是哪个拦截器失效 我们可以通过在每个…

    Java 2023年5月25日
    00
  • springmvc4+hibernate4分页查询功能实现

    让我来详细讲解一下“springmvc4+hibernate4分页查询功能实现”的完整攻略。 1. 前言 在开发Web应用过程中,分页查询功能是经常会用到的一项功能。SpringMVC和Hibernate是当前较为流行的Web开发框架,结合起来使用可以实现很好的分页功能。下面,我们将详细说明如何使用SpringMVC和Hibernate实现分页查询功能。 2…

    Java 2023年6月15日
    00
  • Java新手入门学习之正则表达式

    Java新手入门学习之正则表达式 什么是正则表达式? 正则表达式是一种描述字符串模式的语言,可以通过正则表达式来搜索、匹配、替换和分割文本。在Java中,可以使用Java的正则表达式API来完成对于字符串的处理。 Java中正则表达式的基本语法 Java中正则表达式的基本语法如下: pattern.matcher(str).method() 其中patter…

    Java 2023年5月27日
    00
合作推广
合作推广
分享本页
返回顶部