Java:有效括号字符串验证器

2024-09-01 17:20

本文主要是介绍Java:有效括号字符串验证器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Java实现的有效括号字符串验证器

引言

在编程中,经常需要验证一组字符串中的括号是否正确配对。例如,检查一段代码或表达式中的圆括号、方括号和花括号是否成对出现。这类问题不仅在编程语言解析器中非常重要,也是许多软件开发场景中的基础需求。本文将介绍一种基于Java语言实现的有效括号字符串验证器,并通过JUnit框架对其进行测试。

问题描述

给定一个只包含 '(', ')', '{', '}', '[', ']' 的字符串 s,编写一个函数来检验字符串中的括号是否有效。有效的括号字符串需满足:

  1. 开闭括号必须以正确的顺序出现。
  2. 每个开括号必须有相应闭括号。
  3. 每个闭括号必须有相应开括号。

设计思路

为了解决这个问题,我们可以使用栈的数据结构来追踪每个开括号。当我们遇到一个开括号时,就将其压入栈中;当我们遇到一个闭括号时,就需要检查栈顶的开括号是否与之匹配。如果不匹配或栈为空,则字符串无效。如果遍历完成后栈为空,则说明所有的括号都正确配对。

实现代码

以下是使用Java语言实现的有效括号字符串验证器的代码:

import java.util.Stack;public class Solution {public boolean isValid(String s) {Stack<Character> stack = new Stack<>();for (char c : s.toCharArray()) {switch (c) {case '(':case '[':case '{':stack.push(c);break;case ')':if (stack.isEmpty() || stack.pop() != '(') return false;break;case ']':if (stack.isEmpty() || stack.pop() != '[') return false;break;case '}':if (stack.isEmpty() || stack.pop() != '{') return false;break;default:// 忽略非括号字符break;}}return stack.isEmpty();}public static void main(String[] args) {Solution solution = new Solution();System.out.println(solution.isValid("()[]{}")); // 应该输出 trueSystem.out.println(solution.isValid("(]"));     // 应该输出 falseSystem.out.println(solution.isValid("([)]"));   // 应该输出 falseSystem.out.println(solution.isValid("{[]}"));   // 应该输出 true}
}

代码解释

  1. 初始化栈:使用Stack类创建一个空栈。
  2. 遍历字符串:将字符串转换为字符数组,并遍历每个字符。
  3. 入栈:遇到开括号时,将其压入栈中。
  4. 匹配并出栈:遇到闭括号时,检查栈是否为空,如果为空或栈顶元素与当前闭括号不匹配,则返回false;否则弹出栈顶元素。
  5. 返回结果:如果栈为空,则所有括号都已正确配对,返回true;否则返回false
单元测试

为了确保代码的正确性和健壮性,我们可以使用JUnit框架编写测试用例:

import org.junit.Test;
import static org.junit.Assert.*;public class SolutionTest {private Solution solution = new Solution();@Testpublic void testIsValid() {assertTrue(solution.isValid("()"));assertTrue(solution.isValid("()[]{}"));assertFalse(solution.isValid("(]"));assertFalse(solution.isValid("([)]"));assertTrue(solution.isValid("{[]}"));}
}
import java.util.Stack;public class Solution {/*** 检查字符串中的括号是否有效配对。** @param s 输入的字符串,只包含'(',')','[',']','{','}'。* @return 如果字符串中的括号有效配对,返回true;否则返回false。*/public boolean isValid(String s) {char[] parentheses = {'(', ')', '[', ']', '{', '}'};int i = 0;char c;int[] sum = {0, 0, 0}; // 用于记录每种括号的数量Stack<Integer> top = new Stack<>(); // 用于存放遇到的开括号// 遍历字符串中的每个字符while (i < s.length) {c = s.charAt(i);// 检查字符是否为开括号for (int j = 0; j <= 2; j++) {if (c == parentheses[j]) {top.push(j); // 将对应的索引值推入栈sum[j]++; // 记录开括号数量增加} else if (c == parentheses[j + 3]) {// 检查字符是否为闭括号if (top.size() == 0 || top.peek() != j) {// 栈为空或栈顶的开括号与当前闭括号不匹配,返回falsereturn false;}top.pop(); // 弹出栈顶的开括号sum[j]--; // 记录开括号数量减少}// 如果既不是开括号也不是闭括号,则忽略}i++;}// 遍历完成之后检查每种括号的数量是否为0for (int j = 0; j <= 2; j++) {if (sum[j] != 0) {// 如果有任何一种括号数量不为0,说明有未配对的括号,返回falsereturn false;}}// 如果所有括号都正确配对,返回truereturn true;}public static void main(String[] args) {Solution solution = new Solution();System.out.println(solution.isValid("()[]{}")); // 应该输出 trueSystem.out.println(solution.isValid("(]"));     // 应该输出 falseSystem.out.println(solution.isValid("([)]"));   // 应该输出 falseSystem.out.println(solution.isValid("{[]}"));   // 应该输出 true}
}

代码解释

  1. 初始化变量

    • parentheses 数组存储了所有可能的括号字符。
    • sum 数组用于记录每种类型括号的数量。
    • top 栈用于存放遇到的开括号的索引值。
  2. 遍历字符串

    • 使用 while 循环遍历字符串中的每个字符。
    • 使用内部 for 循环检查字符是否为开括号或闭括号。
  3. 处理开括号

    • 如果字符是开括号,将其对应的索引值推入栈,并在 sum 数组中对应位置增加计数。
  4. 处理闭括号

    • 如果字符是闭括号,检查栈是否为空或栈顶的开括号是否与之匹配。
    • 如果不匹配或栈为空,则返回 false
    • 否则,弹出栈顶的开括号,并在 sum 数组中对应位置减少计数。
  5. 检查括号数量

    • 在遍历完成后,检查每种括号的数量是否为零。
    • 如果有任何一种括号数量不为零,则返回 false
  6. 返回结果

    • 如果所有括号都正确配对,返回 true

结论

通过上述方法,我们成功实现了一个简单而高效的括号字符串验证器。该验证器利用栈的先进后出特性,有效地解决了括号配对问题。此外,通过JUnit测试框架,我们还确保了代码的质量和可靠性。这对于软件开发中的各种应用场景都是非常有用的。
有效括号

这篇关于Java:有效括号字符串验证器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1127571

相关文章

Spring @Scheduled注解及工作原理

《Spring@Scheduled注解及工作原理》Spring的@Scheduled注解用于标记定时任务,无需额外库,需配置@EnableScheduling,设置fixedRate、fixedDe... 目录1.@Scheduled注解定义2.配置 @Scheduled2.1 开启定时任务支持2.2 创建

SpringBoot中使用Flux实现流式返回的方法小结

《SpringBoot中使用Flux实现流式返回的方法小结》文章介绍流式返回(StreamingResponse)在SpringBoot中通过Flux实现,优势包括提升用户体验、降低内存消耗、支持长连... 目录背景流式返回的核心概念与优势1. 提升用户体验2. 降低内存消耗3. 支持长连接与实时通信在Sp

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

Mac系统下卸载JAVA和JDK的步骤

《Mac系统下卸载JAVA和JDK的步骤》JDK是Java语言的软件开发工具包,它提供了开发和运行Java应用程序所需的工具、库和资源,:本文主要介绍Mac系统下卸载JAVA和JDK的相关资料,需... 目录1. 卸载系统自带的 Java 版本检查当前 Java 版本通过命令卸载系统 Java2. 卸载自定

springboot下载接口限速功能实现

《springboot下载接口限速功能实现》通过Redis统计并发数动态调整每个用户带宽,核心逻辑为每秒读取并发送限定数据量,防止单用户占用过多资源,确保整体下载均衡且高效,本文给大家介绍spring... 目录 一、整体目标 二、涉及的主要类/方法✅ 三、核心流程图解(简化) 四、关键代码详解1️⃣ 设置

Java Spring ApplicationEvent 代码示例解析

《JavaSpringApplicationEvent代码示例解析》本文解析了Spring事件机制,涵盖核心概念(发布-订阅/观察者模式)、代码实现(事件定义、发布、监听)及高级应用(异步处理、... 目录一、Spring 事件机制核心概念1. 事件驱动架构模型2. 核心组件二、代码示例解析1. 事件定义

SpringMVC高效获取JavaBean对象指南

《SpringMVC高效获取JavaBean对象指南》SpringMVC通过数据绑定自动将请求参数映射到JavaBean,支持表单、URL及JSON数据,需用@ModelAttribute、@Requ... 目录Spring MVC 获取 JavaBean 对象指南核心机制:数据绑定实现步骤1. 定义 Ja

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再