menu = { '北京': { '海淀': { '五道口': { 'soho': {}, '网易': {}, 'google': {} }, '中关村': { '爱奇艺': {}, '汽车之家': {}, 'youku': {}, }, '上地': { '百度': {}, }, }, '昌平': { '沙河': { '老男孩': {}, '北航': {}, }, '天通苑': {}, '回龙观': {}, }, '朝阳': {}, '东城': {}, }, '上海': { '闵行': { "人民广场": { '炸鸡店': {} } }, '闸北': { '火车战': { '携程': {} } }, '浦东': {}, }, '山东': {} }
递归实现:
def threemenu(dic): while True: for key in dic: print(key) key = input('输入名字:').strip() if key == 'b' or key == 'q':return key if key in dic.keys() and dic[key]: ret = threemenu(dic[key]) if ret == 'q': return 'q' elif (not dic.get(key)) or (not dic[key]): continue threemenu(menu)
堆栈实现:
l = [menu] while l: for key in l[-1]:print(key) k = input('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