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日

相关文章

  • Spring Boot 2.x 把 Guava 干掉了选择本地缓存之王 Caffeine(推荐)

    下面我将详细讲解 Spring Boot 2.x 把 Guava 干掉了选择本地缓存之王 Caffeine(推荐)的攻略。 背景 在 Spring Boot 2.x 版本中,默认使用的是 Caffeine 作为本地缓存框架,而在之前的版本中,默认使用的是 Guava,这是因为,Caffeine 有更好的性能和更多的特性。 步骤 下面是使用 Caffeine …

    Java 2023年5月20日
    00
  • Java中equals()方法实例详解

    Java中equals()方法实例详解 在Java语言中,Object类中的equals()方法用来比较对象的内容是否相等。相较于Java中的”==”运算符来说,它比较的不是变量在内存中的地址,而是变量的内 容。因此,equals()方法在很多时候比”==”更加实用。 equals方法的详细用法 public boolean equals(Object ob…

    Java 2023年5月26日
    00
  • Java编程实现springMVC简单登录实例

    下面我来详细讲解Java编程实现springMVC简单登录实例的攻略,包括如何搭建环境、代码实现过程和相关注意事项。 环境搭建 在实现SpringMVC登录功能之前,我们需要完成相关的环境搭建。以下是必要的环境要求: JDK 8或以上版本 Eclipse IDE for Enterprise Java Developers(或其他Java开发环境) Mave…

    Java 2023年5月16日
    00
  • java实现简单的扫雷小游戏

    讲解”Java实现简单的扫雷小游戏”的攻略,以下是具体步骤: 第一步:界面设计 扫雷游戏主要分为三个步骤:游戏开始、游戏进行中、游戏结束。我们需要根据这些状态设计出对应的UI界面,具体需要设计的内容包括: 开始界面:包括游戏标题、游戏难度选择、开始游戏按钮。 进行中界面:包括剩余雷数、当前用时、扫雷主界面、游戏菜单等。 结束界面:包括胜利或失败的提示、重新开…

    Java 2023年5月19日
    00
  • Java开发者就业需要掌握的9大专业技能

    关于Java开发者就业需要掌握的9大专业技能,我们可以从以下几点展开讲解: 1. Java基础知识 Java基础知识是Java开发者必须掌握的基础技能之一。包括基本的语法、面向对象的特性、集合框架、异常处理、多线程等。只有深入理解Java语言的基本机制,才能为后续的高级知识打下牢固的基础。 示例:如何实现一个简单的Java程序?请编写一个Hello Worl…

    Java 2023年5月20日
    00
  • 反射的作用是什么?

    反射是指在程序运行时动态地访问和操作一个类的属性、方法或构造器。Java的反射机制为我们提供了在运行时动态地创建对象、访问对象的属性和方法、获取类加载器信息等强大的能力,使得我们能够编写更加灵活、通用的代码。下面是详细的使用攻略: 1. 获取Class对象 在Java中,要想使用反射机制必须先获取到相应的Class对象。获取Class对象的方式有三种: 使用…

    Java 2023年5月10日
    00
  • springboot如何关掉tomcat容器

    要关闭 Spring Boot 内嵌的 Tomcat 容器,我们可以通过修改 application.properties 或者 application.yml 文件来配置。下面是具体的步骤: 在 application.properties 文件中添加以下配置: server.shutdown=graceful 或在 application.yml 文件中…

    Java 2023年5月19日
    00
  • 基于PHP实现栈数据结构和括号匹配算法示例

    让我分步为您讲解“基于PHP实现栈数据结构和括号匹配算法示例”的详细攻略。 1. 栈数据结构的实现 栈是一种简单的数据结构,它可以在常量时间内进行插入和删除操作,被称为“先进后出”的数据结构,其中最新保存的元素始终处于栈的顶部。 在 PHP 中可以用数组实现一个栈结构,例如以下的代码块: class Stack { protected $stack; pub…

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