如何拼合所有包含字符串的嵌套IF语句?

时间:2015-06-10 06:36:53

标签: python nested

我正在制作一个选择你自己的文字冒险游戏,到目前为止,它包含了太多的嵌套。示例代码在下面=我的格式相同,只是嵌套更多 - 有时接近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"

1 个答案:

答案 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)