W1ND123 发表于 2021-9-26 19:15:55

python第二十讲动手题01

想知道有没有大佬可以改进的,并且是萌新能够接受的改进,望答复,感谢!!!!!!!!!

洛阳城 发表于 2021-9-27 10:45:08

本帖最后由 洛阳城 于 2021-9-27 10:48 编辑

如果你指的是这道题:

请编写一个程序,判断给定的字符串 s 中括号的写法是否合法。
条件:
字符串仅包含 '('、')'、'['、']'、'{'、'}' 这三对括号的组合
左右括号必须成对编写,比如 "()" 是合法的,"(" 则是非法的
左右括号必须以正确的顺序闭合,比如 "{()}" 是合法的,"{(})" 则是非法的

我个人的想法是先判断一共有多少个字符,如果为单数那肯定不匹配,如果是双数,那就用第一个和最后一个进行对应,第二个和倒数第二个对应......直到中间那对,如果有不对应的那就算不匹配,如果都对应那就算匹配,代码如下:
temp = input("请输入字符串:")
lenght = len(temp)
if((lenght%2) != 0):
    flag = False
else:
    flag = True
    for i in range(lenght//2):
      print("“%s”和“%s”匹配" % (temp, temp))
      if(temp == "(" and temp == ")"):
            pass
      elif(temp == "[" and temp == "]"):
            pass
      elif(temp == "{" and temp == "}"):
            pass
      else:
            flag = False
            break
if(flag):
    print("匹配")
else:
    print("不匹配")另外,鱼C社区的小伙伴们都很乐于助人的,但是如果问题的描述太过空乏那真的没有几个人愿意回答,就像你这个问题。
如果能直接把题目放上来而不是“python第二十讲动手题”可能会有更多鱼友愿意回答。因为描述的很多都不够详细,比如究竟是老教程还是新教程的第20讲,其次可能人家没买那个课后习题,还有就是你指的“改进”是在哪个基础上进行的,是匹配的逻辑还是实现的代码?

W1ND123 发表于 2021-9-28 09:56:57

洛阳城 发表于 2021-9-27 10:45
如果你指的是这道题:

请编写一个程序,判断给定的字符串 s 中括号的写法是否合法。


感谢!!!!!!
页: [1]
查看完整版本: python第二十讲动手题01