猜年龄,有三次机会,如何做?

  1. 检查 输入的数据是否合法,通过异常try来处理,并记录 输入错误次数

  2. 通过累加器,判断是否猜了3次,并提示还剩余多少的机会

  3. 当3次错误,跳出

#!/usr/bin/python3

def guess_age(name, real_age):
'''猜年龄,有三次机会'''
count = 0
print('%s来猜猜我的年龄来' % name)
while True:
error_number = 0
while True: # 验证是否输入合法 try:
maybe_age = int(input("%s:" % name))
except:
error_number += 1
print('调皮,不想玩了,已经答非所问 %s 次了' % error_number)
else:
break count += 1
if maybe_age == real_age:
if count == 1:
print('%s真的太棒了,居然马上就猜中了' % name)
else:
print('%s真的太ben了,居然猜了这么多次才猜中,你居然猜了 %s 次' % (name, count))
break
elif maybe_age > real_age:
print('我有那么老么?滚滚滚,再给你%d机会'%(3-count))
elif count == 3:
print('不和你玩了,真的ben!!!!!!!')
break
elif maybe_age < real_age:
print('嗯哼,把我年龄说的那么低,暗示我智商低?哼,还给你%d机会' % (3-count)) if __name__ == '__main__':
guess_age(name='北门吹雪', real_age=18)

  猜年龄进阶

    猜年龄,并且记录最近5次猜的数据,并保存下来,下次打开程序,历史记录依旧保存

#!/usr/bin/python3

import pickle
import os
from random import randint
from collections import deque def guess_age(age): # 判断输入是否合法
try:
age = int(age)
except:
print('输入错误,重新输入')
return 'error'
if age == real_age:
print('猜对了')
return 'ok'
elif age > real_age:
print('猜大了')
return None
elif age < real_age:
print('猜小了')
return None if __name__ == '__main__':
# 判断历史记录是否存在
if os.path.exists('history'):
try:
# 存在就打开
history = pickle.load(open('history', 'br'))
except:
# 打开失败或者损坏重新定义
history = deque([], 5)
else:
# 不存在声明新的q,[]表示初始列表,5表示长度
history = deque([], 5)
# 生成随机数
real_age = randint(1, 100)
while True:
age = input('(1~100)输入:')
# 查询历史命令
if age == 'history' or age == 'h?':
print(list(history))
continue
result = guess_age(age)
history.append(age)
# 判断是否猜对
if result == 'ok':
break
# 退出程序
if age == 'q':
break
# 把历史数据写入文件
pickle.dump(history, open('history', 'bw'))

python_猜年龄的更多相关文章

  1. 我的python中级班学习之路(全程笔记第一模块) (第一章)(第2部分:如何设置python中的字体颜色,猜年龄练习题解答,while else语句,pycharm的使用)

    第一章:  python 基础语法 第  2  部分: 一.猜年龄练习题解答 直接上代码 >>> age = 26 >>> count = 0 >>&g ...

  2. python 小程序,猜年龄

    要求如下:

  3. 基于虹软 2.0 人脸识别猜年龄 java版 demo

    首先感谢虹软,是你们提供这么好的SDK支撑了我们的想象力! 这是一个用javav编写的可视化应用,用户通过自己的脸和计算机进行交互,计算机则通过萌萌女孩的语音和用户对话.核心程序就是利用ArcFace ...

  4. {python}完成完整的温度转换程序 猜数字游戏(猜价格,猜年龄等) 解析身份证号、学号不同片段的含义

    完成完整的温度转换程序 while True: a = int(input("如果是华氏转摄氏,请按1\n,如果是摄氏转华氏,请按2\n")) if a==1: h = float ...

  5. Python练习-猜年龄的LowB游戏

    Alex大神今天让我做一个猜年龄的游戏: 第一个游戏是你只能猜三次:真的很LowB啊~ # 编辑者:闫龙 #猜年龄游戏,3次后程序自动退出! ages = 29; #for循环3次 for i in ...

  6. python基础代码(猜年龄、从最内层跳出多层循环、简单的购物车程序)

    1.猜年龄 , 可以让用户最多猜三次! age = 55 i=0 while i<3: user_guess = int (input ("input your guess:" ...

  7. day03_11 if语句实现猜年龄01

    老男孩猜年龄游戏 age_of_princal = 56 guess_age = int( input(">>:") ) #以下为伪代码 ''' if guess_ag ...

  8. python猜年龄游戏升级版

    猜年龄游戏升级版 要求:允许用户最多尝试3次,每尝试3次后,如果还没猜对,就问用户是否还想继续玩,如果回答Y,就继续让其猜3次,以此往复,如果回答N,就退出程序,如何猜对了,就直接退出 age = 1 ...

  9. 用python写了一个猜年龄小游戏

    写一个猜年龄游戏: 需要实现用户登录的功能 初始用户登录信息为 {'hades': '13579','nick': '123','ruixing': 'a1','fanping': 'b2'} 登录时 ...

随机推荐

  1. chrome调试工具高级不完整使用指南(实战一)

    三.chrome调试工具实战 3.1 获取界面对应的HTML和修改样式 我们以博客园为例子来分析. 通过上面的操作就可以定位到对应的HTML代码 左侧菜单显示的就是当前指定元素层叠样式的一个情况 上面 ...

  2. SGML/HTML/XML之间的关系

    1 历史起源 SGML--1986年国际标准化组织出版发布了一个信息管理方面的国际标准(ISO 8879:1986信息处理). HTML 2.0--1995年11月作为RFC 1866发布 XML 1 ...

  3. ES6小点心第二弹——底部浮现弹窗

    小点心,顾名思义,开箱即食,拿来即用. 献上第二个小点心:SlidePopup. GitHub 在线演示 GitHub 上欢迎大家来找茬^_^ 前端朋友们,今天要介绍的这款小点心牛B了.相信是个前端都 ...

  4. 从交叉熵损失到Facal Loss

    1交叉熵损失函数的由来1.1关于熵,交叉熵,相对熵(KL散度) 熵:香农信息量的期望.变量的不确定性越大,熵也就越大,把它搞清楚所需要的信息量也就越大.其计算公式如下: 其是一个期望的计算,也是记录随 ...

  5. JS 生成唯一数字

    如题,在JS中,利用Date.getTime()来生成唯一数字,用于ID function uniqueNumber() { var date = Date.now(); if (date <= ...

  6. 开发高性能JAVA应用程序基础(集合篇)

    集合类在开发中使用非常频繁,使用时合理的选择对提高性能小有帮助.而且大部分面试都会有与集合相关的问题,例如ArrayList和LinkedList的对比. 了解API的集成与操作架构,才能了解何时该采 ...

  7. Two 观察者 observer pattern

    Two 观察者 定义 在对象之间定义一对多的依赖,当一个对象改变状态,依赖它的对象都会收到通知.并自动更新. 可以观察者自取,也可以主题去推送 其实就是设计两个接口. 相关原则 为交互对象之前的松耦合 ...

  8. Redux 核心概念

    http://gaearon.github.io/redux/index.html ,文档在 http://rackt.github.io/redux/index.html .本文不是官方文档的翻译. ...

  9. 【Java学习笔记之十五】Java中的static关键字解析

    Java中的static关键字解析 static关键字是很多朋友在编写代码和阅读代码时碰到的比较难以理解的一个关键字,也是各大公司的面试官喜欢在面试时问到的知识点之一.下面就先讲述一下static关键 ...

  10. [bzoj3702] 二叉树

    一个节点的儿子是否交换,不会影响到它和兄弟节点间的逆序对数. 所以每次合并线段树的时候算一下交换与不交换的逆序对数,然后选个较小值就行了. #include<cstdio> #includ ...