自定义数据结构-括号匹配

题目描述
满足如下条件的字符串称为括号匹配的字符串:

  1. 空字符串是括号匹配的字符串。
  2. 若A是括号匹配的串,则(A)、[A]是括号匹配的字符串。
  3. 若A、B是括号匹配的字符串,则AB也是括号匹配的字符串。 例如:()、[]、([])、()()都是括号匹配的字符串,而][、[(])则不是。 现在对于输入的字符串,判断它是否是括号匹配的字符串。

输入:一行,为一个仅由“(”、“)”、“[”、“]”组成的非空字符串。
输出:一行,“YES”或“NO”,分别表示输入的字符串括号匹配或不匹配。

括号匹配的主要思路是
先看输入的是不是左括号,如果是的话则让其加入列表,如果不是且列表为空则让逻辑变量为0
如果列表不为空且输入的是右括号则判断和前一个左括号是否匹配,如果不匹配则逻辑变量为0,如果匹配就把与其匹配的左括号删除,进行下一步判断
最后结合state的值和列表是否为空判断括号是否匹配

a = input()
b = []
state =
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值