概率分析:为什么葫芦娃救爷爷是一个一个地救成功率最高?

简介: 概率分析:为什么葫芦娃救爷爷是一个一个地救成功率最高?

前言

  过完年了返工后想起了小孩子们爱看的葫芦娃救爷爷的动画片,葫芦娃为什么是一个一个前去救爷爷,为什么不等着七个一起去救爷爷。带着这个疑问,我决定今天用数学的角度建模计算下哪种方式救爷爷成功率最高?

情节回顾

image.png   

故事开始时,爷爷被蛇精抓走,大娃(力大无穷)决定去救爷爷,但由于他轻敌,被蛇精骗入陷阱。接着,二娃(千里眼顺风耳)、三娃(铜头铁臂)、四娃(喷火)、五娃(喷水)、六娃(隐身)都分别去救爷爷,但都因为各自的弱点而失败。但最终七个葫芦娃在一起联手击败了蛇精。

建模

  这里我们进行精简情节回顾的逻辑并给出关键信息:

  1. 七个葫芦娃联手是100%击败蛇精;
  2. 单个葫芦娃击败蛇精的概率是1/7;
  3. 爷爷在第6天营救失败后必死;
  4. 爷爷在每天死的概率是1/6;

这里我们可以得到葫芦娃营救爷爷的成功的条件为:爷爷没死 + 葫芦娃击败蛇精 。在这里可以设置一个长度为6的数组(因为第七天七个葫芦娃会联手)对葫芦娃进行数据组合计算营救爷爷成功的概率,经过计算共有132种营救方式,其中成功概率最高的救是一个一个前去营救爷爷,在数组中表示为:[1,1,1,1,1,1] ;其概率为0.3965694566039661

python实现

shell

复制代码

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)


相关文章
|
5月前
|
安全 NoSQL Java
单体项目偶遇并发漏洞!短短一夜时间竟让老板蒸发197.83元!
单体项目偶遇并发漏洞。故事基于真实事件而改编,如有雷同,纯属巧合~
|
8月前
|
缓存 Java 关系型数据库
踩了定时线程池的坑,导致公司损失几千万,血的教训
踩了定时线程池的坑,导致公司损失几千万,血的教训
|
JavaScript 小程序 Shell
🤒如果老板搞代码量统计,打工人如何自救?
“一个下午做出一个微信小程序”,“一个下午搞定业务方案”,每天写1000行代码的成绩,大家你们真的做得到吗?
345 0
🤒如果老板搞代码量统计,打工人如何自救?
|
存储 数据采集 运维
业务系统故障率居高不下:有哪些非常有效的治理大招?
业务系统故障率居高不下:有哪些非常有效的治理大招?
368 0
|
供应链 安全 定位技术
疫情期间上班风险预估
目前抗疫到了关键时期,而来自各方面复工的呼声也不断涌出 这两天,甚至有朋友圈里的老板,认为感染的风险不过是千万分之几 作为上班族,最关心的也是自身的复工感染风险,毕竟每个人背后都是一个家庭,一人感染全家感染 所以,我以自己为例简单做了一个出行风险分析,希望对大家也有帮助 1.
1235 0
疫情期间上班风险预估
|
Web App开发 边缘计算 缓存
停课不停学,优酷直播如何将网课点名延迟降到0.6s?
受疫情影响,各中小学校延迟开学,优酷宣布发起“在家上课计划”,为无法到校教学的老师们提供免费的直播授课工具,直播课程将于2月10日开始陆续上线,在直播过程中如何提升和保障流畅的互动体验?优酷直播流媒体团队做了低延时流媒体技术的探索实践,实现了在用户体验不下降的基础上,让主播与主播延时<300ms,播与粉丝延时<600ms,解决了直播间各类互动问题。接下来,阿里文娱的乾戒将具体介绍探索过程。
1469 0
停课不停学,优酷直播如何将网课点名延迟降到0.6s?
|
Cloud Native 中间件 测试技术
支付宝双11工程师:半个月升级几十次,峰值到来前紧张到手抖
蚂蚁金服金融级分布式架构 SOFAStack 获得了“十三五”金融科技产业示范案例奖
1238 0
支付宝双11工程师:半个月升级几十次,峰值到来前紧张到手抖
|
安全
网银安全恐慌“后遗症”凸显 肉鸡检测器下载量近百万
4月8日,记者从金山毒霸客服中心了解到,近段时间,用户对网银安全问题尤为关注。大量用户表示对网银的安全性表示担忧,网银安全恐慌“后遗症”显现。 据了解,央视今年3•15晚会曝光了受到木马攻击的“肉鸡”电脑,用户网上银行账号受到威胁之后,“肉鸡”一词就以迅雷不及掩耳之势传遍了全国。
988 0

热门文章

最新文章

相关实验场景

更多