zoukankan      html  css  js  c++  java
  • 小试牛刀

    一、Python基础实战之猜年龄游戏

    1、给定年龄,用户可以猜三次年龄
    
    2、年龄猜对,让用户选择两次奖励
    
    3、用户选择两次奖励后可以退出
    
    age = 18  # 答案
    count = 0  # 游戏次数控制
    prize_dict = {0: '布娃娃', 1: '变形金刚', 2: '奥特曼', 3: '《Python从入门到放弃》'}
    
    # 核心代码
    while count < 3:
        inp_age = input('请输入你的年龄>>>')  # 与用户交互
    
        # 判断用户是否骚扰(超纲:判断用户输入的是否为数字)
        if not inp_age.isdigit():
            print('傻逼,你的年龄输错了')
            continue
    
        inp_age_int = int(inp_age)
    
        # 核心逻辑,判断年龄
        if inp_age_int == age:
            print('猜对了')
    
            print(prize_dict)  # 打印奖品
    
            # 获取两次奖品
            for i in range(2):
                prize_choice = input(
                    '请输入你想要的奖品,如果不想要,则输入"n"退出!!!')  # 与用户交互获取奖品
    
                # 判断是否需要奖品
                if prize_choice != 'n':
                    print(f'恭喜你获得奖品: {prize_dict[int(prize_choice)]}')
                else:
                    break
            break
    
        elif inp_age_int < age:
            print('猜小了')
    
        else:
            print('猜大了')
    
        count += 1  # 成功玩一次游戏
    
        if count != 3:
            continue
    
        again_choice = input('是否继续游戏,继续请输入"Y",否则任意键直接退出.')  # 交互是否再一次
    
        # 判断是否继续
        if again_choice == 'Y':
            count = 0
    

    二、Python进阶实战之三级菜单

    1、打印省、市、县三级菜单
    
    2、可返回上一级
    
    3、可随时退出程序
    

    1、1面条版

    menu = {
        '北京': {
            '海淀': {
                '五道口': {
                    'soho': {},
                    '网易': {},
                    'google': {}
                },
                '中关村': {
                    '爱奇艺': {},
                    '汽车之家': {},
                    'youku': {},
                },
                '上地': {
                    '百度': {},
                },
            },
            '昌平': {
                '沙河': {
                    '老男孩': {},
                    '北航': {},
                },
                '天通苑': {},
                '回龙观': {},
            },
            '朝阳': {},
            '东城': {},
        },
        '上海': {
            '闵行': {
                "人民广场": {
                    '炸鸡店': {}
                }
            },
            '闸北': {
                '火车战': {
                    '携程': {}
                }
            },
            '浦东': {},
        },
        '山东': {},
    }
    
    tag = True
    while tag:
        menu1 = menu
        for key in menu1:  # 打印第一层
            print(key)
    
        choice1 = input('第一层>>: ').strip()  # 选择第一层
    
        if choice1 == 'b':  # 输入b,则返回上一级
            break
        if choice1 == 'q':  # 输入q,则退出整体
            tag = False
            continue
        if choice1 not in menu1:  # 输入内容不在menu1内,则继续输入
            continue
    
        while tag:
            menu_2 = menu1[choice1]  # 拿到choice1对应的一层字典
            for key in menu_2:
                print(key)
    
            choice2 = input('第二层>>: ').strip()
    
            if choice2 == 'b':
                break
            if choice2 == 'q':
                tag = False
                continue
            if choice2 not in menu_2:
                continue
    
            while tag:
                menu_3 = menu_2[choice2]
                for key in menu_3:
                    print(key)
    
                choice3 = input('第三层>>: ').strip()
                if choice3 == 'b':
                    break
                if choice3 == 'q':
                    tag = False
                    continue
                if choice3 not in menu_3:
                    continue
    
                while tag:
                    menu_4 = menu_3[choice3]
                    for key in menu_4:
                        print(key)
    
                    choice4 = input('第四层>>: ').strip()
                    if choice4 == 'b':
                        break
                    if choice4 == 'q':
                        tag = False
                        continue
                    if choice4 not in menu_4:
                        continue
    
                    # 第四层内没数据了,无需进入下一层
    

    1、2文艺青年版

    menu = {
        '北京': {
            '海淀': {
                '五道口': {
                    'soho': {},
                    '网易': {},
                    'google': {}
                },
                '中关村': {
                    '爱奇艺': {},
                    '汽车之家': {},
                    'youku': {},
                },
                '上地': {
                    '百度': {},
                },
            },
            '昌平': {
                '沙河': {
                    '老男孩': {},
                    '北航': {},
                },
                '天通苑': {},
                '回龙观': {},
            },
            '朝阳': {},
            '东城': {},
        },
        '上海': {
            '闵行': {
                "人民广场": {
                    '炸鸡店': {}
                }
            },
            '闸北': {
                '火车战': {
                    '携程': {}
                }
            },
            '浦东': {},
        },
        '山东': {},
    }
    
    # part1(初步实现):能够一层一层进入
    layers = [
        menu,
    ]
    
    while True:
        current_layer = layers[-1]
        for key in current_layer:
            print(key)
    
        choice = input('>>: ').strip()
        
        if choice == 'q':
            break
    
        if choice not in current_layer: continue
    
        layers.append(current_layer[choice])
    
    # part2(改进):加上退出机制
    layers = [
        menu,
    ]
    
    while True:
        if len(layers) == 0: break
        current_layer = layers[-1]
        for key in current_layer:
            print(key)
    
        choice = input('>>: ').strip()
    
        if choice == 'b':
            layers.pop(-1)
            continue
        if choice == 'q': break
    
        if choice not in current_layer: continue
    
        layers.append(current_layer[choice])
    
  • 相关阅读:
    hdu 2227
    小A的数学题
    E
    F
    C
    Ping-Pong (Easy Version)的解析
    余数之和BZOJ1257
    大数求余
    数论学习 算法模板(质数,约数)
    Acwing 197. 阶乘分解
  • 原文地址:https://www.cnblogs.com/gfhh/p/11512906.html
Copyright © 2011-2022 走看看