asd734619 发表于 2022-3-17 08:18:51

求助,为什么运行不了啊,关于判断[],(),{}是否完整的算法

a = []
a.extend(input())
b = ["{","[","(",")","]","}"] #创建一个查找表
c = 0
for c in range(len(a) // 2):
    if b.index(a) + 1 == -b.index(a[-c:1]):#将输入元素与查找表元素对比,满足对称则输出ok
      print("ok")
    else:
      print("no")
输入[],报错显示的是['['] is not in list

asd734619 发表于 2022-3-17 14:05:29

a = []
a.extend(input())
b = ["{","[","(",")","]","}"] #创建一个查找表
c = 0
#c = b.index(a) + 1
for c in range(len(a) // 2):
    if b.index(a) + 1 == 6 - b.index(a[-c-1]):#将输入元素与查找表元素对比,满足对称则输出ok
      print("ok")
    else:
      print("no")
我改了一下,这样就行了,但是只能判断对称输入的情况

甲鱼python 发表于 2022-3-17 10:26:58

本帖最后由 甲鱼python 于 2022-3-17 11:21 编辑

a = list(input("请输入括号:"))
while a != []: # 不输入任何字符,退出循环
    b = []
    flag = True
    for c in a:
      if c == '(' or c == '['or c == '{':
            b.append(c)
      elif c == ')':
            if len(b) == 0 or b.pop() != '(':
                flag = False
      elif c == ']':
            if len(b) == 0 or b.pop() != '[':
                flag = False
      elif c == '}':
            if len(b) == 0 or b.pop() != '{':
                flag = False
    if len(b) != 0:
      flag = False

    if flag == False:
      print("括号不成对")
      a = list(input("请输入括号:"))
    else:
      print("括号成对")
      a = list(input("请输入括号:"))
   
   

leafu 发表于 2022-3-17 10:43:09

-b.index(a[-c:1]) 这个报错了
首先,a[-c:1]这个得到的是一个列表,而index函数查找的是元素,格式不匹配所以报错。index() 函数用于从列表中找出某个值第一个匹配项的索引位置。

leafu 发表于 2022-3-17 10:45:08

leafu 发表于 2022-3-17 10:43
-b.index(a[-c:1]) 这个报错了
首先,a[-c:1]这个得到的是一个列表,而index函数查找的是元素,格式不匹配 ...

建议直接用in判断

python爱好者. 发表于 2022-3-17 10:48:22

但算法有问题:
a = []
a.extend(input("请输入(每个括号建要有一个空格):").split(" "))
b = ["{","[","(",")","]","}"] #创建一个查找表
c = 0
for c in range(len(a) // 2):
    if b.index(a) + 1 == -(b.index(a[-c:1])):#将输入元素与查找表元素对比,满足对称则输出ok
      print("ok")
    else:
      print("no")

python爱好者. 发表于 2022-3-17 10:54:32

leafu 发表于 2022-3-17 10:45
建议直接用in判断

他这不是检测在不在列表中的意思,是检测是否成对!不能用 in !!!
页: [1]
查看完整版本: 求助,为什么运行不了啊,关于判断[],(),{}是否完整的算法