Files
lab_dice/dice_stats.py

76 lines
1.7 KiB
Python

from die import Die
from tqdm import tqdm
class FiveDice:
def __init__(self):
self.dice = [Die() for number in range(5)]
def roll(self):
for die in self.dice:
die.roll()
return self.faces()
def faces(self):
return [die.face for die in self.dice]
def all_ones(self):
for face in self.faces():
if face != 1:
return False
return True
def three_of_a_kind(self):
face_counts = {}
for face in self.faces():
if face in face_counts:
face_counts[face] += 1
else:
face_counts[face] = 1
for count in face_counts.values():
if count >= 3:
return True
return False
def four_of_a_kind(self):
face_counts = {}
for face in self.faces():
if face in face_counts:
face_counts[face] += 1
else:
face_counts[face] = 1
for count in face_counts.values():
if count >= 4:
return True
return False
dice = FiveDice()
successes = 0
trials = 1000000
for trial in tqdm(range(trials)):
dice.roll()
if dice.all_ones():
successes += 1
print(f"all ones + {successes/trials}")
three_of_a_kind_successes = 0
four_of_a_kind_successes = 0
for trial in tqdm(range(trials)):
dice.roll()
if dice.three_of_a_kind():
three_of_a_kind_successes += 1
print(f"three of a kind: {three_of_a_kind_successes / trials}")
for trial in tqdm(range(trials)):
dice.roll()
if dice.four_of_a_kind():
four_of_a_kind_successes += 1
print(f"four of a kind: {four_of_a_kind_successes / trials}")