三级菜单

menu = {
'北京': {
'海淀': {
'五道口': {
'soho': {},
'网易': {},
'google': {}
},
'中关村': {
'爱奇艺': {},
'汽车之家': {},
'youku': {},
},
'上地': {
'百度': {},
},
},
'昌平': {
'沙河': {
'老男孩': {},
'北航': {},
},
'天通苑': {},
'回龙观': {},
},
'朝阳': {},
'东城': {},
},
'上海': {
'闵行': {
"人民广场": {
'炸鸡店': {}
}
},
'闸北': {
'火车战': {
'携程': {}
}
},
'浦东': {},
},
'山东': {},
}

堆栈写法:
l=[menu]
while l:for key in l[-1]:print(key)
    k=input('>>>').strip()
    if k in l[-1].keys() and l[-1][k]:
        l.append(l[-1][k])
    elif k=='b':
        l.pop()
    elif k=='q':
        break
    else:
        continue

递归方法:

def threeLM(dic):
    while True:
        for k in dic:
            print(k) #北京 上海 山东
        key = input('input>>').strip()
        if key == 'b' or key == 'q':
            return key
        elif key in dic.keys() and dic[key]:
            ret = threeLM(dic[key]) #调用
            if ret == 'q': return 'q'

threeLM(menu)

 






































































posted @ 2018-10-25 14:12  洛水卿卿  阅读(137)  评论(0)    收藏  举报