关键词: Python 、葫芦娃 、 概率计算 、 数学 、 建模
前言
过完年了返工后想起了小孩子们爱看的葫芦娃救爷爷的动画片,葫芦娃为什么是一个一个前去救爷爷,为什么不等着七个一起去救爷爷。带着这个疑问,我决定今天用数学的角度建模计算下哪种方式救爷爷成功率最高?
情节回顾
故事开始时,爷爷被蛇精抓走,大娃(力大无穷)决定去救爷爷,但由于他轻敌,被蛇精骗入陷阱。接着,二娃(千里眼顺风耳)、三娃(铜头铁臂)、四娃(喷火)、五娃(喷水)、六娃(隐身)都分别去救爷爷,但都因为各自的弱点而失败。但最终七个葫芦娃在一起联手击败了蛇精。
建模
这里我们进行精简情节回顾的逻辑并给出关键信息:
- 七个葫芦娃联手是100%击败蛇精;
- 单个葫芦娃击败蛇精的概率是1/7;
- 爷爷在第6天营救失败后必死;
- 爷爷在每天死的概率是1/6;
这里我们可以得到葫芦娃营救爷爷的成功的条件为:爷爷没死 + 葫芦娃击败蛇精 。在这里可以设置一个长度为6的数组(因为第七天七个葫芦娃会联手)对葫芦娃进行数据组合计算营救爷爷成功的概率,经过计算共有132种营救方式,其中成功概率最高的救是一个一个前去营救爷爷,在数组中表示为:[1,1,1,1,1,1] ;其概率为0.3965694566039661
python实现
def build_strategy(idx, sum_val, cur):
global res
if idx == N and sum_val == N:
res.append(cur.copy())
return
if idx >= N:
return
for i in range(idx + 1, -1, -1):
if sum_val + i <= idx + 1:
tmp = cur.copy()
tmp.append(i)
build_strategy(idx + 1, sum_val + i, tmp)
def all_strategies(n):
global N, res
N = n
res = []
build_strategy(0, 0, [])
return res
def calc_probability(strategy):
prob = 0.0
try_cnt = 0
succ_prob = 1.0 / (N + 1)
for i in range(len(strategy)):
live_grandpa_prob = (N - i) * 1.0 / N
save_prob = strategy[i] * succ_prob
prob += (1 - succ_prob) ** try_cnt * live_grandpa_prob * save_prob
try_cnt += strategy[i]
return prob
N = 6
Strategy_list = []
probability_list = []
result = all_strategies(N) # Get the list of strategies using the all_strategies function
for strategy in result:
probability = calc_probability(strategy)
Strategy_list.append(strategy)
probability_list.append(probability)
print(f"Strategy: {strategy}, Probability: {probability}")
max_probability = max(probability_list)
print(max_probability)
如果你对Python感兴趣,想要学习python,这里给大家分享一份Python全套学习资料,都是我自己学习时整理的,希望可以帮到你,一起加油!
😝有需要的小伙伴,可以V扫描下方二维码免费领取🆓
1️⃣零基础入门
① 学习路线
对于从来没有接触过Python的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
② 路线对应学习视频
还有很多适合0基础入门的学习视频,有了这些视频,轻轻松松上手Python~
③练习题
每节视频课后,都有对应的练习题哦,可以检验学习成果哈哈!
2️⃣国内外Python书籍、文档
① 文档和书籍资料
3️⃣Python工具包+项目源码合集
①Python工具包
学习Python常用的开发软件都在这里了!每个都有详细的安装教程,保证你可以安装成功哦!
②Python实战案例
光学理论是没用的,要学会跟着一起敲代码,动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。100+实战案例源码等你来拿!
③Python小游戏源码
如果觉得上面的实战案例有点枯燥,可以试试自己用Python编写小游戏,让你的学习过程中增添一点趣味!
4️⃣Python面试题
我们学会了Python之后,有了技能就可以出去找工作啦!下面这些面试题是都来自阿里、腾讯、字节等一线互联网大厂,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
上述所有资料 ⚡️ ,朋友们如果有需要的,可以扫描下方👇👇👇二维码免费领取🆓