我正在制作一个选择你自己的文字冒险游戏,到目前为止,它包含了太多的嵌套。示例代码在下面=我的格式相同,只是嵌套更多 - 有时接近10层深。
我的问题是:有什么方法可以压扁它吗?字符串意味着我需要每个IF语句在每次有效时打印一些内容,所以我不能只使用' AND'像这样:
if A and B:
do something
elif C and D:
do something else
我已经想过把重复的部分放在他们自己的功能中,但是在这种情况下那不会提高可读性 - 至少,不是我能弄明白的。
帮助?
print "First String"
choice = raw_input("Choose A or B")
if choice == "A":
print "You Chose A"
choice = raw_input("Choose C or D")
if choice == "C":
print "You Chose C"
choice = raw_input("Choose E or F")
if choice == "E" or choice == "F":
print "END"
elif choice == "D":
print "You Chose D"
choice = raw_input("Choose G or H")
if choice == "G" or choice == "H":
print "END"
elif choice == "B":
print "You Chose B"
choice = raw_input("Choose I or J")
if choice == "I":
print "You Chose I"
choice = raw_input("Choose C or D")
if choice == "C":
print "You Chose C"
choice = raw_input("Choose E or F")
if choice == "E" or choice == "F":
print "END"
elif choice == "D":
print "You Chose D"
choice = raw_input("Choose G or H")
if choice == "G":
print "END"
elif choice == "H":
print "You Chose H"
choice = raw_input("Choose K or L")
if choice == "K" or choice == "L":
print "END"
答案 0 :(得分:2)
如果映射是直截了当的,比如说,如果我先选择A,我可以选择C或D,如果我先选择B,我可以选择C或E.现在在C中,不管是否第一个选择是A或B,你得到的选择是一样的。然后你可以使用递归和像
这样的字典dict = {'-1':['A','B'], 'A' : ['C','D'] , 'B':['I','J'], 'C':['E','F'] ..}
然后是一个递归函数,如 -
def choose(previousChoice, num):
print str(num) + " String"
choice = raw_input("Choose " + ' or '.join(dict[previousChoice]) + " :")
if dict.get(choice) != None and len(dict.get(choice)) > 0:
choose(choice, num + 1)
在上面的例子中,你以 -
开头choose('-1',1)