python第二十讲动手题01
想知道有没有大佬可以改进的,并且是萌新能够接受的改进,望答复,感谢!!!!!!!!! 本帖最后由 洛阳城 于 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讲,其次可能人家没买那个课后习题,还有就是你指的“改进”是在哪个基础上进行的,是匹配的逻辑还是实现的代码? 洛阳城 发表于 2021-9-27 10:45
如果你指的是这道题:
请编写一个程序,判断给定的字符串 s 中括号的写法是否合法。
感谢!!!!!!
页:
[1]