鱼C论坛

 找回密码
 立即注册
查看: 74|回复: 3

[已解决](([](())))这样的括号也是合法的吗?

[复制链接]
发表于 前天 23:07 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
## 在完成列表二的课后作业中,我发现了这个问题
s = input("请输入测试字符串:")

# 创建一个特殊列表
stack = []
   
for c in s:
    # 如果是左括号,那么添加到特殊列表中
    if c == '(' or c == '[' or c == '{':
        stack.append(c)
    # 如果是右括号的情况
    else:
        # 如果碰到右括号,但特殊列表中没有左括号,那么肯定是非法的
        if len(stack) == 0:
            print("非法T_T")
            break
   
        # 逐个给出 c 对应的右括号 d
        if c == ')':
            d = '('
        elif c == ']':
            d = '['
        elif c == '}':
            d = '{'
   
        # 对比 d 和从特殊列表尾部弹出的元素
        if d != stack.pop():
            print("非法T_T")
            break
else:
    # 如果循环走完,特殊列表不为空,那么肯定是左括号比右括号多的情况
    # 那肯定有同学会问:右括号比左括号多的情况在哪里判断?
    # 小甲鱼答:在上面 d != stack.pop() 的判断中已经可以排除了~
    if len(stack) == 0:
        print("合法^o^")
    else:
        print("非法T_T")

## 这个程序输入(([](()))),结果是合法的
最佳答案
昨天 01:22
(([](())))这样的括号也是合法的
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 前天 23:08 | 显示全部楼层
是的,"(((())))" 这样的括号字符串是合法的括号匹配。因为:

1. 每个左括号 ( 都有对应的右括号 ) 闭合
2. 括号的开闭顺序正确(没有交叉或未闭合的情况)
3. 左括号数量(4个)等于右括号数量(4个)

以下是一个验证括号匹配的代码示例:


  1. s = input("请输入测试字符串:")
  2. stack = []  # 创建空栈

  3. for c in s:
  4.     if c == '(':
  5.         stack.append(c)  # 左括号入栈
  6.     elif c == ')':
  7.         if not stack:    # 栈为空时遇到右括号
  8.             print("非法!")
  9.             break
  10.         stack.pop()      # 弹出栈顶左括号
  11. else:
  12.     # 循环正常结束时检查栈是否为空
  13.     if not stack:
  14.         print("括号合法!")
  15.     else:
  16.         print("括号非法!")
复制代码


测试结果:
1. 输入 (((()))) → 输出 "括号合法!"
2. 输入 ()()) → 输出 "非法!"(右括号多余)
3. 输入 ((()) → 输出 "括号非法!"(左括号多余)

注意:你代码中的 if c == '(' or c == '': 有错误,空字符串 '' 应该改为其他括号类型(如 '[')才能处理多种括号,若只需处理圆括号可简化为 if c == '('

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 昨天 01:22 | 显示全部楼层    本楼为最佳答案   
(([](())))这样的括号也是合法的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 昨天 07:32 | 显示全部楼层
当然了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-25 16:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表