@本文来源于公众号:csdn2299,喜欢可以关注公众号 程序员学府
本文实例讲述了Python实现破解猜数游戏算法。分享给大家供大家参考,具体如下:
QQ群里的聊天机器人会发起猜数小游戏. 玩法如下:
- 用户发 #猜数 到群里
- 机器人响应: 猜数已经开始, 范围是1-10000之间的某个数
- 你发送 #猜数[123] 到群里
- 机器人响应: 大了或者小了, 或者恭喜你猜中了
- 你根据刚才猜的123, 和返回, 猜一个更小或更大的数, 发送 #猜数[111] , 即返回第2步
那么最好的猜测方法肯定是找居中的数了, 由于心算耗时, 所以直接上python脚本破解这个:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
__author__ = 'huhu, <huyoo353@126.com>'
def find_middle(start, end):
#print start, end
return round((start+end)/2.0)
if __name__ == '__main__':
start, end = '',''
text = raw_input(u"> 输入猜数的范围(如:421-499 或者421 499 或者421,499):").decode('gb18030')
spliters = '-, '
for c in spliters:
if text.find(c) != -1:
num_list = text.split(c)
if ''.join(num_list).isdigit():
start, end = num_list[0],num_list[1]
break
if start == '' or end == '':
print u'范围不正确'
else:
start = int(start)
end = int(end)
count = 1
last_guess = find_middle(start,end)
while 1:
result = raw_input(u"放弃猜测直接回车, 等于输入=, 小了输入1, 大了请输入2\n>>> #猜数[%d] ,对吗?> " % last_guess ).decode('gb18030')
#print type(text)
if result in ['q','e','exit','quit','bye',u'退出']:
print 'Bye!'
break
else:
result=result.strip()
if result == '1':
start = last_guess
last_guess = find_middle(last_guess,end)
elif result == '2':
end = last_guess
last_guess = find_middle(start,last_guess)
elif result == '=':
print u'恭喜猜中, 共猜了%d次' % count
print u'#猜数[%d]' % last_guess
break
else: #
continue
count += 1
非常感谢你的阅读
大学的时候选择了自学python,工作了发现吃了计算机基础不好的亏,学历不行这是没办法的事,只能后天弥补,于是在编码之外开启了自己的逆袭之路,不断的学习python核心知识,深入的研习计算机基础知识,整理好了,我放在我们的微信公众号《程序员学府》,如果你也不甘平庸,那就与我一起在编码之外,不断成长吧!
其实这里不仅有技术,更有那些技术之外的东西,比如,如何做一个精致的程序员,而不是“屌丝”,程序员本身就是高贵的一种存在啊,难道不是吗?[点击加入]
想做你自己想成为高尚人,加油!