骰子原题:
小明参加了少年宫的一项趣味活动:每个小朋友发给一个空白的骰子(它的6个面是空白的,没有数字),要小朋友自己设计每个面写哪个数字。但有如下要求:
1. 每个面只能填写 0 至 8 中的某一个数字。
2. 不同面可以填写同样的数字,但6个面总和必须等于24。
填好后,小朋友可以用自己填写好数字的骰子向少年宫的两个机器人挑战----玩掷骰子游戏。规则如下:
三方同时掷出自己的骰子,如果出现任何相同的数字,则三方都不计分。
如果三方数字都不同,则最小数字一方扣 1 分,最大数字一方加 1 分。
小明看到了两个机器人手中的骰子分别是:
0 0 0 8 8 8
1 1 4 5 6 7
请你替小明算一下,他如何填写,才能使自己得分的概率最大。
请提交小明应该填写的6个数字,按升序排列,数字间用一个空格分开。
如果认为有多个答案,提交字母序最小的那个方案。
请严格按照格式,通过浏览器提交答案。
注意:只提交一行内容,含有6个被空格分开的数字。不要写其它附加内容,比如:说明性的文字。
思路逻辑:
-
生成器:骰子6面数字和 == 24,排列组合来说,这个规则限定了排列的可能性总量
-
随机生成小明骰子搭配所有的可能存为npz文档,读为ming_list_All
-
模拟投骰子一次的状况,判断win条件,True时win_count + 1
-
每一组ming_list,模拟10000次投骰子实验,
计算对应此组ming_list的win_count值,
并记录在列表win_count_list中(100个数字) -
用max[win_count_list],并index此数定位,找到对应该组的ming_list数字搭配
完成
代码部分
先做一个生成器
将生成的小明可写的数组组合存在ming_list.npy当中,等待调用
xlist = []
ming_list = []
def dice_generate():
for x1 in range(0, 9):
for x2 in range(0, 9):
for x3 in range(0, 9):
for x4 in range(0, 9):
for x5 in range(0, 9):
for x6 in range(0, 9):
xlist = [x1, x2, x3, x4, x5, x6]
if sum(xlist) == 24:
ming_list.append(xlist)
else:
continue
dice_generate()
np.save('ming_list.npy', ming_list)
生成的ming_list列表元素个数有32661个(满足和为24),这里明显32661个数据如果做迭代、并且打印(print)的话,会让机器运行时间过长。后期注意要用 if - else 条件语句缩短运行时间。
print(len(ming_list)) # 32661
这段代码写完后,开启另一个py文件,调用刚生成的ming_list.npy即可,否则后面的命名会复杂。
选择ming_list当中一个组来进行骰子投掷试验
另开新的py文档后,import numpy as np的部分我省略了,如需要复刻请加上。
以第234组数据作为小明的骰子,与两个机器人同时投掷一次的代码如下:
ming_list_All = np.load('ming_list.npy')
ming_list_234 = ming_list_All[