括号匹配问题(不用栈,用数组)

本文探讨了如何不用栈,而是使用数组来解决括号匹配问题。通过建立数组,遇到左括号时入栈,遇到右括号时出栈。重点在于理解栈顶指针的移动,以及如何判断括号匹配的正确性和错误情况,如栈空时遇到右括号,或者处理结束后栈非空的情况。
摘要由CSDN通过智能技术生成

不用模板栈的话,就是建立一个数组,输入若是左括号,则入栈,stack[++top]=a[i],top为栈顶元素的指针,若是右括号,则出栈,stack[top--]。

此处关键是自增符号的顺序,为什么入栈要先加,出栈后减,因为栈顶指针永远都是最后一个元素前一个位置,入栈的时候要先移动指针,到上一个,才可以进栈。

还有要判断什么时候栈空,遇到右括号,如果此时栈空,即top==0,则左边没有元素了,这样就是不匹配的(可以联想如果输入的第一个就是右括号的情况比较好想到)。还有就是最后判断,如果输入元素都判断完,若最后栈是空的,则所有元素都匹配成功,是对的。若最后栈不是空的,则还有剩余元素没有匹配,此时是不匹配的。


描述
现在,有一行括号序列,请你检查这行括号是否配对。
输入
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值