华为OD机试C卷-- 表达式括号匹配(Java & JS & Python & C)

博客主要介绍了如何解决华为在线开发者测试(OD)中的一道括号匹配问题。通过遍历表达式并使用栈来检查括号匹配,分别提供了Java、Python和JavaScript的算法源码。题目要求判断输入表达式的括号是否匹配,匹配则输出括号对数,否则输出-1。
摘要由CSDN通过智能技术生成

获取题库不需要订阅专栏,可直接私信我进入CSDN领军人物top1博主的华为OD交流圈观看完整题库、最新面试实况、考试报告等内容以及大佬一对一答疑。

题目描述
(1+(2+3)*(3+(8+0))+1-2)这是一个简单的数学表达式,今天不是计算它的值,而是比较它的括号匹配是否正确。

前面这个式子可以简化为(()(()))这样的括号我们认为它是匹配正确的,

而((())这样的我们就说他是错误的。注意括号里面的表达式可能是错的,也可能有多个空格,对于这些我们是不用去管的,

我们只关心括号是否使用正确。

输入描述
给出一行表达式(长度不超过 100)。

输出描述
如果匹配正确输出括号的对数,否则输出-1。

题目解析
这个问题是一个经典的栈应用问题,用于检查括号是否匹配。我们可以遍历整个表达式,每当遇到左括号时,就将一个占位符(例如 ‘(’)压入栈中;当遇到右括号时,检查栈顶元素是否为对应的左括号。如果是,则将栈顶元素弹出;如果不是或栈为空,则说明括号不匹配。

在这个问题中,我们不需要区分不同类型的括号(如小括号、中括号、大括号),因为输入表达式只包含小括号 ()。我们只需要维护一个栈来跟踪尚未匹配的左括号即可。

java算法源码

import 
  • 8
    点赞
  • 200
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值