2018-12-27

15-8 同时掷三个骰子:
同时掷三个D6骰子,可能得到的最小点数为3,而最大点数为18。请通过可视化展示同时掷三个D6骰子的结果。
die.py

from random import randint
class Die():
    #标识一个骰子的类
    def __init__(self,num_sides=6):
        #骰子为六面
        self.num_sides = num_sides
    def roll(self):
        #返回一个位于1和骰子面数之间的随机值
        return randint(1,self.num_sides)

die_visual.py

from die import Die
import pygal
#创建一个D6
die_1 = Die()
die_2 = Die()
die_3 = Die()

results = []
for roll_num in range(10000):
    result = die_1.roll()+die_2.roll()+die_3.roll()
    results.append(result)
print(results)
#分析结果
frequencies=[]
max_result = die_1.num_sides + die_2.num_sides+die_3.num_sides
for value in range(3,max_result+1):
    frequenciey = results.count(value)
    frequencies.append(frequenciey)
print(frequencies)
#对结果可视化
hist = pygal.Bar()
hist.title = "Results of rolling one D6 1000 times."
hist.x_labels = []
for aaa in range(3,19):
    apws = aaa
    hist.x_labels.append(apws)
hist.x_title = "Resultaaaa"
hist.y_title = "Frequency of Resultbbbb"

hist.add('D6666',frequencies)
hist.render_to_file('die_visual.svg')

15-9 将点数相乘 将点数相乘 :同时掷两个骰子时,通常将它们的点数相加。请通过可视化展示将两个骰子的点数相乘的结果。
答案:
die.py不变

die_visual.py

from die import Die
import pygal
#创建一个D6
die_1 = Die()
die_2 = Die()

results = []
for roll_num in range(10000):
    result = die_1.roll()*die_2.roll()
    results.append(result)
print(results)
#分析结果
frequencies=[]
max_result = die_1.num_sides * die_2.num_sides
for value in range(1,max_result+1):
    frequenciey = results.count(value)
    frequencies.append(frequenciey)
print(frequencies)
#对结果可视化
hist = pygal.Bar()
hist.title = "Results of rolling one D6 1000 times."
hist.x_labels = []
for aaa in range(1,37):
    apws = aaa
    hist.x_labels.append(apws)
hist.x_title = "Resultaaaa"
hist.y_title = "Frequency of Resultbbbb"

hist.add('D6666',frequencies)
hist.render_to_file('die_visual.svg')

15-10 练习使用本章介绍的两个库 练习使用本章介绍的两个库 :尝试使用matplotlib通过可视化来模拟掷骰子的情况,并尝试使用Pygal通过可视化来模拟随机漫步的情况
问题一
die.py不变
die_visual.py

import matplotlib.pyplot as plt
from die import Die

die_1 = Die()
die_2 = Die()
results = []

for roll_num in range(1000):
    result = die_1.roll() + die_2.roll()
    results.append(result)
print(results)
frequencies = []
max_result = die_1.num_sides + die_2.num_sides
for value in range(1, max_result + 1):
    frequency = results.count(value)
    frequencies.append(frequency)
print(frequencies)
plt.plot(list(range(1, max_result + 1)), frequencies, linewidth=2)
plt.title("Result of rolling me D6 1000 times.")
plt.xlabel("Result", fontsize=14)
plt.ylabel("Square of D6 1000 times")
plt.show()

问题二

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 见一女人穿着高跟鞋,婀娜多姿,袅袅婷婷地走过,优雅而妩媚,细细的鞋跟不由地替她倒吸一口凉气,同事说,“女人穿与不穿...
    蓝小愚阅读 522评论 2 7
  • 参加个人成长训练营第二期,从第一期懵懂状态到现在逐步明确,还学会了用思维导图做课堂笔记,课程讲完了笔记也做完了...
    淑智阅读 207评论 0 1
  • 那年 坐落庭前你秀发如烟 信手拈花映了谁的脸 独坐庭前 手里拨弄琴弦 恰逢诗意少年 淡淡微笑晕染了那一年 你的脸现...
    小草_8b39阅读 340评论 0 0
  • 文/靠谱的大树 读书真的很重要 ①刘媛媛《寒门贵子》演讲视频, ②张雪峰怒怼M丁演讲视频。 读书很重要。这句话仅仅...
    靠谱的大树阅读 509评论 0 1