滚动多个骰子并取观察到的最大值并绘制直方图

rolling multiple dice and taking the max value observed and plotting a histogram

考虑一个你掷多个骰子并取观察到的最大值的事件。我正在编写一个函数,它将多次随机模拟此事件,并且 return 每次试验中获得的最大值。

不确定我所做的是否正确。此外,我想绘制结果最大值的直方图,但 plt.hist 似乎不正确。 任何见解将不胜感激

import random
def multipleRolls(numberoftrials, numberofdice):
   trial_list=[]
   min = 1
   max = 6
   for i in range (1,numberoftrials+1):
       m=0
       for j in range(1,numberofdice+1):
           k = random.randint(min, max)
           if m<k:
               m=k
       trial_list.append(m)
   plt.hist(trial_list)
   plt.show()
   print(trial_list)
multipleRolls(3,5)

为了证明掷出的骰子数量正确并且选择了最大值,您可以创建一个包含所有掷骰子的列表并打印答案,然后将结果传递给正常 plt.hist,示例:

import random
def multipleRolls(numberoftrials, numberofdice):
   trial_list=[]
   alltrials=[]
   min = 1
   max = 6
   for i in range (1,numberoftrials+1):
       singletrial=[]
       m=0
       for j in range(1,numberofdice+1):
           k = random.randint(min, max)
           if m<k:
               m=k
           singletrial.append(k)    
       alltrials.append(singletrial)
       trial_list.append(m)
       
   return trial_list, alltrials

trial_list, alltrials = multipleRolls(3,5)
print(trial_list, alltrials)

import matplotlib.pyplot as plt

plt.hist(trial_list)
plt.show()

示例响应:

[5, 6, 6] [[1, 1, 5, 1, 5], [5, 2, 6, 2, 4], [5, 2, 6, 4, 6]]