king120727 2022-10-18 21:32 采纳率: 100%
浏览 105
已结题

python判断括号是否匹配

输入一个表达式(长度小于100),该表达式可以包括开括号、闭括号、数字、符号和字母,例如:
Y = 4 * 5 + (x 7) * 10
请编写一个程序来查找不平衡的括号。在一行中输出表达式,并在表达式下面标记不平衡的括号。不平衡的左括号被标记为“$”,不平衡的右括号被标记为“?”。
输出的例子:
((A+B-7*(6-5)
$$
)(r+5-(e-6))/9-8)(
? ?$

  • 写回答

2条回答 默认 最新

  • ·星辰大海 2022-10-18 22:08
    关注
    
    a='((A+B-7*(6-5)'
    stack=[]
    error=[]
    for i,j in enumerate(a):
        if j=='(':
            stack.append([i,j])
        if j==')':
            if stack:
                if stack[-1][-1]=='(':
                    stack.pop()
                else:
                    error.append((i,1))
            else:
                error.append((i,1))
    while stack:
        temp=stack.pop()
        if temp[-1]=='(':
            error.append((temp[0],2))
        else:
            error.append((temp[0],1))
    L=[' ' for _ in range(len(a))]
    for i in error:
        if i[-1]==1:
            L[i[0]]='?'
        else:
            L[i[0]]='$'
    print(a)
    print(''.join(L))
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 10月26日
  • 已采纳回答 10月18日
  • 修改了问题 10月18日
  • 修改了问题 10月18日
  • 展开全部

悬赏问题

  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)
  • ¥15 Vue3地图和异步函数使用
  • ¥15 C++ yoloV5改写遇到的问题
  • ¥20 win11修改中文用户名路径
  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
  • ¥15 帮我写一个c++工程
  • ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
  • ¥15 关于smbclient 库的使用