今天在园子里看到博客:超难面试题:甲乙两人互猜数字(数理逻辑)。然后琢磨了半天,写了个Python程序实现算法,我得出来的结果是1,6或1,8或35,42的组合,

不知道是否正确,请高人指点?

下面列出实现算法代码(代码按照题目文字一步步进行的,没有优化):

# -*- coding: utf-8  -*-
#!/usr/local/bin/python def is_prime2(number):
'''
判断数字是否是特殊质数(数学上质数和分解因子相同的数)。分解因子相同的数,如:4,9等。
'''
_is_primenum = True
for item in range(2,number,1):#不考虑1乘以number
if number % item == 0:
if (number/item) == item: #两个因子不能相同
continue
_is_primenum = False
break
return _is_primenum def combination(data, t, vl):
'''
计算一组数的组合
'''
_kk = len(data)
_ret_list = []
for _i in range(_kk-t+1):
vl.append(data[_i])
new_data = data[_i+1:]
if t-1 == 1:
for _j in range(len(new_data)):
_data_str = ','.join(map(str,vl))+','+str(new_data[_j])
_ret_list.append(_data_str)
else:
_ret_list.extend(combination(new_data, t-1, vl))
vl.pop()
return _ret_list def generate_combine(num_list, pick_num):
_v1 = [] # temp variable.
return combination(num_list, pick_num, _v1) def filter_1_a(_combination_list):
'''
甲:“我不知道这两个数是什么” 遍历所有组合,过滤掉能判断出结果的组合
'''
_result_dict = {} # 存储key为乘积的字典,value是组合的数组。
_new_combination_list = [] #存储还有效的组合 #由于甲不知道这两个数,可以肯定乘积不是质数,排除这类组合。
for item in _combination_list:
a, b = item.split(',',1)
_product = int(a) * int(b) #甲得到的数字
if not is_prime2(_product):
if _product in _result_dict:
_result_dict[_product] +=[item]
else:
_result_dict[_product] =[item] _new_result_dict = {} #便于理解,使用一个新变量存字典值
#由于甲不知道,表示value肯定要大于1种组合。
#比如[min=1,max=10], 乘积是15的组合:3*5一种,这样的组合应该排除掉。
for key,value in _result_dict.iteritems():
if len(value) > 1:
_new_result_dict[key] = value
_new_combination_list.extend(value) return _new_combination_list, _new_result_dict def filter_1_b(_combination_list):
'''
乙:“我也不知道” 遍历所有组合,过滤掉能判断出结果的组合
'''
_new_combination_list = [] #存储还有效的组合
_result_dict = {} # 存储key为两值相加的字典,value是组合的数组。 for item in _combination_list:
a, b = item.split(',',1)
_sum = int(a) + int(b) #乙得到的数字
if _sum in _result_dict:
_result_dict[_sum] +=[item]
else:
_result_dict[_sum] =[item] _new_result_dict = {}
#由于乙不知道,表示value肯定要大于1种组合。
for key,value in _result_dict.iteritems():
if len(value) > 1:
_new_result_dict[key] = value
_new_combination_list.extend(value)
return _new_combination_list, _new_result_dict def filter_2_a(_combination_list, product_dict, sum_dict):
'''
甲:“那我知道了” 遍历所有组合,过滤掉能判断出结果的组合
'''
_new_prodcut_dict = {}
#在乘积字典中,去除多余的组合
for key,value in product_dict.iteritems():
_new_value = []
for item in value:
if item in _combination_list:
_new_value.append(item)
if _new_value:
_new_prodcut_dict[key] = _new_value # 去除已经不在相加字典中的组合,
for key,value in _new_prodcut_dict.items():
_new_value = []
for item in value:
a, b = item.split(',',1)
_sum = int(a) + int(b) #乙得到的数字
if _sum in sum_dict:
_new_value.append(item)
_new_prodcut_dict[key] = _new_value # 由于甲知道,表示肯定等于1种组合。
_new_combination_list = [] #存储还有效的组合
_result_dict = {}
for key,value in _new_prodcut_dict.iteritems():
if len(value) == 1:
_result_dict[key] = value
_new_combination_list.extend(value)
return _new_combination_list, _result_dict def filter_2_b(_combination_list, sum_dict):
'''
乙:“那我也知道了” '''
_new_sum_dict = {}
#在相加字典中,去除多余的组合
for key,value in sum_dict.iteritems():
_new_value = []
for item in value:
if item in _combination_list:
_new_value.append(item)
if _new_value:
_new_sum_dict[key] = _new_value
return _new_sum_dict if __name__ == '__main__':
print "start..."
_min_num=1
_max_num=50 #产生数组
_num_list = range(_min_num,_max_num+1,1) #[1,2,3...,49,50] #生成Cn2的所有组合列表,如:['1,6', '2,3', '2,6', '3,4'...]
_combination_list = generate_combine(_num_list, 2) # 甲:“我不知道这两个数是什么”
_combination_list, _result_product_dict = filter_1_a(_combination_list) # 乙:“我也不知道”
_combination_list, _result_sum_dict = filter_1_b(_combination_list) # 甲:“那我知道了”
_new_combination_list, _result_product_dict = filter_2_a(_combination_list, _result_product_dict, _result_sum_dict)
print u"最终的组合:", _new_combination_list
print u"最终的乘积字典:", _result_product_dict # 乙:“那我也知道了”
_result_sum_dict = filter_2_b(_new_combination_list, _result_sum_dict)
print u"最终的相加字典:", _result_sum_dict print "end..."

用python实现了一下:甲乙两人互猜数字(数理逻辑)的更多相关文章

  1. 通过游戏学python 3.6 第一季 第二章 实例项目 猜数字游戏--核心代码--猜测次数 可复制直接使用 娱乐 可封装 函数

      猜数字游戏--核心代码--猜测次数   #猜数字--核心代码--猜测次数 number=33 amount=3 count=0 while count<=amount: conversion ...

  2. 通过游戏学python 3.6 第一季 第九章 实例项目 猜数字游戏--核心代码--猜测次数--随机函数和屏蔽错误代码--优化代码及注释--简单账号密码登陆--账号的注册查询和密码的找回修改--锁定账号--锁定次数--菜单功能'menufile

      通过游戏学python 3.6 第一季 第九章 实例项目 猜数字游戏--核心代码--猜测次数--随机函数和屏蔽错误代码--优化代码及注释--简单账号密码登陆--账号的注册查询和密码的找回修改--锁 ...

  3. 通过游戏学python 3.6 第一季 第八章 实例项目 猜数字游戏--核心代码--猜测次数--随机函数和屏蔽错误代码--优化代码及注释--简单账号密码登陆--账号的注册查询和密码的找回修改--锁定账号--锁定次数

    通过游戏学python 3.6 第一季 第八章 实例项目 猜数字游戏--核心代码--猜测次数--随机函数和屏蔽错误代码--优化代码及注释--简单账号密码登陆--账号的注册查询和密码的找回修改--锁定账 ...

  4. 通过游戏学python 3.6 第一季 第一章 实例项目 猜数字游戏--核心代码 可复制直接使用 娱乐 可封装 函数

    本文实例讲述了python实现的简单猜数字游戏.分享给大家供大家参考.具体如下: 给定一个1-99之间的数,让用户猜数字,当用户猜错时会提示用户猜的数字是过大还是过小,知道用户猜对数字为止,猜对数字用 ...

  5. 甲乙(数理逻辑)转自http://www.cnblogs.com/devymex/p/3329635.html

    这是一道历史悠久,又很困难的面试题. 你在旁观主持人和甲.乙两个天才数学家玩猜数字游戏.主持人准备了两个数,告知甲乙:这两个数不同,且大于等于1,小于等于30.然后主持人将两数之积告诉甲,把两数之和告 ...

  6. python 读取wav 音频文件的两种方式

    python 中,常用的有两种可以读取wav音频格式的方法,如下所示: import scipy from scipy.io import wavfile import soundfile as sf ...

  7. python中如何调用函数交换两个变量的值

    python中如何调用函数交换两个变量的值 所有代码来在python3.7.1版本实现 以下实例通过用户输入两个变量,并相互交换:  方法一: def swap(a,b): # 创建临时变量,并交换 ...

  8. Python 数据库的Connection、Cursor两大对象

    Python 数据库的Connection.Cursor两大对象 pymysql是Python中操作MySQL的模块,其使用方法和py2的MySQLdb几乎相同. Python 数据库图解流程 Con ...

  9. 今盒子里有n个小球,A、B两人轮流从盒中取球,每个人都可以看到另一个人取了多少个

    /* 题目描述 今盒子里有n个小球,A.B两人轮流从盒中取球,每个人都可以看到另一个人取了多少个,也可以看到盒中还剩下多少个,并且两人都很聪明,不会做出错误的判断. 我们约定: 每个人从盒子中取出的球 ...

随机推荐

  1. 称球问题(zt)

    下面说的这个问题可能大家都看到过,它是这么描述的: 现在有n(n>=2)个球,n个球外观一模一样,但是重量有区别,其中有且仅有一个球的重量比其它n-1个球要重,现在有一个天平,天平是完好无损的, ...

  2. Asp.Net 之 调用分享接口

    一.后台分享方式 腾讯QQ.腾讯空间.腾讯微博.新浪微博分享接口,如下: 注意:在网站对接前,请先申请注册好您的QQ登录appid.新浪登录Appkey.腾讯微博appkey. //腾讯QQ分享 ht ...

  3. Lifting the Stone

    我们需要把一块石头平稳的从地板上拿起来.石头的底面是多边形且各个部分的高度都一样,我们需要找出石头的重心. input 测试案例  T; 每组第一行给出N,表示定点数. 接下来N行,每行连个数,表示坐 ...

  4. html笔记03:表单

    1.表单是用来收集用户填写的信息,可以说表单就是一个容器,里面的元素的类型可以不一样,所表示的功能也不同. 表单基本语法: <html> <head> <title> ...

  5. python(1) - 输入和输出

    前面已经说过了,print()函数括号里加上字符串,就可以实现输出 >>> print('This is Python!') This is Python! print()函数也可以 ...

  6. 安装.Net framework 3.5 sp1报错的解决方法

    错误日志,提示: [11/22/07,18:04:40] Microsoft .NET Framework 2.0a: [2] Error: Installation failed for compo ...

  7. 转:java 类名 this 的使用

    转自: http://www.cnblogs.com/PengLee/p/3993033.html 类名.class与类名.this详解   类名.class      我们知道在java中,一个类在 ...

  8. saltstack实战2--远程执行之目标(target)

    target 就是目标的意思,你要在那台机器上执行此命令或此状态.或者说将此动作或者状态文件推送给谁来执行,让那个minion执行可以进行一些匹配 对于拥有大量机器的环境,如果单独一台台的执行指定mi ...

  9. 关于IE6的一些常见的CSS BUG处理

    CSS BUG:样式在各浏览器中解析不一致的情况,或者说CSS样式在浏览器中不能正确显示的问题称为CSS BUG: CSS Hack:css hack是指一种兼容css 在不同浏览器中正确显示的技巧方 ...

  10. HttpClient(4.3.5) - HTTP Authentication

    HttpClient provides full support for authentication schemes defined by the HTTP standard specificati ...