在某次作业中,涉及到需要从列表中找到最接近定值的元素。
需要注意的是,列表中最接近该定值的元素可能不止一个
该作业原题是:实现多人猜谜游戏。在1-100中随机生成一个整数作为谜底,找出与谜底最为接近的参赛选手名称。
#编写程序自动生成0到100间的一个随机数,然后让参与者输入昵称和数字,最后判断谁猜得最准。
import random
import numpy as np
y = random.randrange(1,100)
res = {}
n = int(input('请输入游戏总人数:\n'))
a = 0
print('谜底是:',y)
while(a < n):
name = input('请输入姓名:\n')
ans = int(input('请输入数字:\n'))
res[name] = ans
a = a+1
grades = list(res.values())#记录了每个参赛者的答案
#不足 best_grade = min(grades, key=lambda x: abs(x - y))
grades_abs = list(map(lambda x:abs(x-y),grades))#记录了每个参赛者和谜底的接近程度
peo_grade = list(np.where(np.array(grades_abs) ==