一道编程劝退题,检测你是否适合干编程

news2024/9/27 9:28:50

前言

大家都知道要想成为一名优秀的开发工程师,需要数学基础好,即你要有很强的逻辑思维能力,这里有一道美国斯坦福大学出的一道逻辑思维的测试测试,检测你的逻辑思维能力,大家可以看看自己逻辑能力怎么样。

题目

有一个抽奖活动,有三扇门,一扇门后是汽车,另外两扇后是山羊,你第一次选择其中一扇门后,主持人,会打开另外两扇门中的一个是山羊的门,然后,再次让你做选择,是坚持第一次的选择还是选择换门,请问参加这次活动抽中汽车的概率是多少?

下面有几个选项供大家选择

A .1/3

B.1/2

C.1/6

D.2/3

E. 5/6

答案

恭喜你选对了,你猜的没错,答案就是D,中将的概率是三分之二,这是一个简单的数学概率问题。

解析

首先这次抽奖包含了两次选择,单独把每次选择分开来看,第一次中将的概率是1/3,第二次中将的概率是1/2,问题的关键是要把两次选择当成一个过程去计算概率,还有一点值得注意的是,最终的结果是第二次选择为准的,也就是说,无论你第一次是否选择对了小汽车,如果第二次,没选中的话,也是没用。下面我们列出第一次和第二次选择的所有可能。

第一次

第二次

山羊

山羊(不换们)

山羊

汽车(换门)

山羊

山羊(不换们)

山羊

汽车(换门)

汽车

山羊(换门)

汽车

汽车(不换们)

由上图可以看出,第一次 所有可能出现的结果中,汽车出现了两次,山羊出现了4次,第一次就抽中汽车的概率是1/3,第二次,由于主持人打开一扇门,帮我们排除了一个山羊选项。第二次所有的可能 汽车出现了3次,山羊出现了两次,所有第二次选中汽车的概率是1/2。但是到这里,我们是统计了换门和不换们,一起的概率。假设我们第二次都选择换门的话,出现的所有可能,就是下图所示

第一次

第二次

山羊

汽车(换门)

山羊

汽车(换门)

汽车

山羊(换门)

由上图可以看出, 所有可能出现的结果中,汽车出现了两次,山羊出现了一次,由此看见,只要我们,第一次和第二次选择不同的门,即第二次选择换门,我门的中将概率奖达到最大2/3。

验证

下面用代码模拟,人工选择,操作一万次,看看统计中将次数占比,做验证。


import cn.hutool.core.util.RandomUtil;
import com.google.common.collect.Lists;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;

public class MockDraw {

    public static void main(String[] args) {
        List<String> result=new ArrayList<>(10000);
        for (int i = 0; i < 10000; i++) {
            result.add(raffle());
        }
        Map<Object, Long> groupMap=result.stream().collect(Collectors.groupingBy(e->e,Collectors.counting()));
        System.out.println(groupMap);

    }

    private static String  raffle(){
        //三个门的编号1,2,3
        List<Integer> doors= Lists.newArrayList(1,2,3);
        //奖品选项
        List<String> prizes= Lists.newArrayList("山羊","汽车","山羊");
        //把奖品随机放到对应的门后面
        String option1=RandomUtil.randomEle(prizes);
        prizes.remove(option1);
        String option2=RandomUtil.randomEle(prizes);
        prizes.remove(option2);
        String option3=RandomUtil.randomEle(prizes);
        prizes.remove(option3);
        Map<Integer,String> map=new HashMap<>(5);
        map.put(1,option1);
        map.put(2,option2);
        map.put(3,option3);
        //第一次选择
        Integer firstSelect= RandomUtil.randomEle(doors);
        //主持人打开一扇有羊的门
        Integer open= openDoor(doors,map,firstSelect);
        //排除打开门的选项
        doors.remove(open);
        //第二次选择(换门)
        Integer second=  doors.stream().filter(e->!e.equals(firstSelect)).findFirst().get();
        return map.get(second);
    }

    private static Integer openDoor(List<Integer> doors, Map<Integer,String> map,Integer firstSelect){
        return doors.stream().filter(door->map.get(door).equals("山羊")&&!firstSelect.equals(door)).findFirst().get();
    }
}

运行结果:

模拟一万次,第二次选择,每次都换门的情况下,最终选中山羊的次数是3322次,选中汽车的次数是6678次,中将概率接近2/3。

第二次不换门,修改代码

    //第二次选择(不换门)
    Integer second=  doors.stream().filter(e->e.equals(firstSelect)).findFirst().get();

运行结果:

模拟一万次,第二次选择,每次都不换门的情况下,最终选中山羊的次数是6636次,选中汽车的次数是3364次,中将概率接近1/3。

模拟一万次,第二次随机选择会怎么样

修改代码:

        //第二次选择(随机)
        Integer second=  RandomUtil.randomEle(doors);

运行结果

模拟一万次,第二次随机选择的情况下,最终选中山羊的次数是4926次,选中汽车的次数是5074次,中将概率接近1/2。

总结

这是一道经典的概率题,所谓的概率只是个估值,只有在多次试验下,才有具有参考意义。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/170376.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

<队列>的概念结构实现【C语言版】

1.队列的概念及结构 队列对于临时数据的处理也十分有趣&#xff0c;它跟栈一样都是有约束条件的数组&#xff08;或者链表&#xff09;。区别在于我们想要按什么顺序去处理数据&#xff0c;而这个顺序当然是要取决于具体的应用场景。 你可以将队列想象成是电影院排队。排在最…

Android Studio 工程导入 AOSP编译的 android.jar

使用场景   1.需要使用 framework 中的 SystemApi 文件或者 hide 的 API 接口   2.定制 Framework 层业务&#xff0c;即有 客制化 的 API 接口 补充知识点   1.framework 源码即 AS 工程目录中 External Libraries 下的 < Android API xx Platform > 下的原生 SDK…

Docker-全面详解(学习总结---从入门到深化)

一、什么是Docker Docker 是一个开源的应用容器引擎&#xff0c;基于 Go 语言 并遵从 Apache2.0 协议开源。 什么是"集装箱技术" 我们都知道码头里的集装箱是运载货物用的&#xff0c;它是一种按规格标准 化的钢制箱子。集装箱的特色&#xff0c;在于其格式划一&…

峰值21WQps、亿级DAU,小游戏《羊了个羊》是怎么架构的?

小游戏《羊了个羊》 短短的7天内&#xff0c;DAU突破了1亿、吞吐量峰值21WQps。 《羊了个羊》运营后台数据显示&#xff0c;在短短的7天内&#xff0c;这款小游戏的DAU就突破了1亿。 要知道&#xff0c;除了王者荣耀、原神等屈指可数的现象级手游之外&#xff0c;1亿DAU是这个…

LeetCode刷题模版:131 - 140

目录 简介131. 分割回文串132. 分割回文串 II133. 克隆图134. 加油站135. 分发糖果136. 只出现一次的数字137. 只出现一次的数字 II138. 复制带随机指针的链表139. 单词拆分140. 单词拆分 II【未理解】结语简介 Hello! 非常感谢您阅读海轰的文章,倘若文中有错误的地方,欢迎您…

【GitHub仓库上传和克隆】

GitHub仓库上传和克隆1. 安装1.1 WindowR:cmd1.2 选择写代码的文件夹右键Git Bash Here1.3 分支管理2. 本地仓库推送给网络仓库2.1 忽略推送文件2.2 本地初始推送3. 克隆3.1 克隆下载3.2 克隆代码修改上传3.2.1 初次推送3.2. 2 后续推送其他1. 安装 1.1 WindowR:cmd //是否安…

Redis从入门到精通(一:Redis入门)

Redis 简介 问题现象 海量用户 高并发 罪魁祸首——关系型数据库性能瓶颈&#xff1a;磁盘IO性能低下扩展瓶颈&#xff1a;数据关系复杂&#xff0c;扩展性差&#xff0c;不便于大规模集群解决思路降低磁盘IO次数&#xff0c;越低越好 —— 内存存储去除数据间关系&#xff0…

ucore lab1,lab2,lab3,lab4链表详解 获取结构体成员偏移

ucore版链表介绍 ucore是清华大学操作系统实验课要完成的操作系统&#xff0c;里面有个链表数据结构我觉得很有意思&#xff0c;记录下来。 ucore将链表与数据对象分离&#xff0c;使得任意数据对象&#xff0c;只要加上一个链表组件就能组织成一个链表。 要使得一个本来不具…

双目相机国产、非国产统计参数对比分析

双目相机国产、非国产统计参数对比分析 ZED ZED是STEREOLABS出品的双目摄像头&#xff0c;广泛应用在科研机构的无人车、协作机械臂上&#xff0c;如图2-1所示。其3D分辨率在Ultra模式下可达到RGB时的分辨率&#xff0c;具体见图2-2&#xff0c;物理尺寸为1753033mm&#xff…

记录一次gateway HandlerStrategies.withDefaults().messageReaders() 导致的内存炸裂的问题

背景 年前出现了一次内存炸裂的生产事故。导致其他请求无法请求通过。 [boundedElastic-55] [Loggers.java:314]:Scheduler worker in group main failed with an uncaught exception [TID:] 2023-01-18 10:40:33.189 [INFO] [boundedElastic-55] [AccessTokenGatewayFilterF…

Arduino基础学习——meArm(太极创客第二部分)

面包板电源模块为机器臂单独供电&#xff0c;机器臂本身有四个小电机驱动作用&#xff0c;如果单独靠arduino来为这四个小电机供电&#xff0c;机器臂可能不会稳定工作&#xff0c;将会抖动。 机械臂的四个动作主要靠四个电机来控制&#xff0c;这四个电机主要连接在我们的ard…

云端IDE系列教程4:TitanIDE + Typora = 鱼和熊掌

概述 目前&#xff0c;大部分技术人员使用 Markdown 编写技术文档已经成了日常工作的一部分&#xff0c;现在市场上也有各种各样的文字编辑工具&#xff1a;石墨文档、有道云笔记、语雀、金山文档、腾讯文档、Google文档&#xff0c;WPS、Office、Typora等。但在云原生时代&am…

vue3学习笔记(总)——ts+组合式API(setup语法糖)

文章目录1. ref全家桶1.1 ref()1.2 isRef()以及isProxy()1.3 shallowRef()1.4 triggerRef()1.5 customRef()1.6 unref()2. reactive全家桶2.1 reactive()2.2 readonly()2.3 shallowReactive() 和 shallowReadonly()3. to系列全家桶3.1 toRef()3.2 toRefs()3.3 toRaw()4. comput…

【年度总结】回看2022,展望2023,做更好的自己

作者主页&#xff1a;Designer 小郑 作者简介&#xff1a;Java全栈软件工程师一枚&#xff0c;来自浙江宁波&#xff0c;负责开发管理公司OA项目&#xff0c;专注软件前后端开发&#xff08;Vue、SpringBoot和微信小程序&#xff09;、系统定制、远程技术指导。CSDN学院、蓝桥云…

Mac 下ZooKeeper安装和使

Mac 下ZooKeeper安装和使用 Apache ZooKeeper分布式协调系统是构建分布式应用程序的高性能服务。 1.下载ZooKeeper 环境要求&#xff1a;ZooKeeper服务器是用Java创建的&#xff0c;它运行在JVM之上。需要安装JDK 7或更高版本。 https://zookeeper.apache.org/releases.html …

1.3 PCIe——硬件实现架构

PCIe的设计可以分为controller和PHY&#xff0c;整体设计较为复杂&#xff0c;一般可向IP厂商定制设计&#xff0c;controller和PHY模块的接口是PIPE接口 一、一般实现架构 1.1 PCIE controller 控制器逻辑包含了IP的host设计&#xff0c;以及PCIe协议中所规定的事务层、数…

AirServer电脑投屏软件免费版使用及切换中文教程

AirServer是由App Dynamic打造的一款投屏软件。AirServer是适用于Mac和Windows的先进的屏幕镜像接收器。可以将手机设备&#xff0c;如iPhone、iPad、安卓上的屏幕投送到电脑屏幕上。特别我们日常开会要给客户演示手机上的操作时&#xff0c;投屏就显得非常专业。当然&#xff…

关于java位移运算的一点讨论

框架乱飞的年代&#xff0c;时常还得往框架源码里看&#xff0c;对内在原理没点理解&#xff0c;人家就会认为你不太行。平时开发你可能没咋用过位移运算&#xff0c;但往源码里一看&#xff0c;就时常能看到它。我也是看着看着&#xff0c;突然仔细一琢磨&#xff0c;又不由得…

【机器学习 - 4】:线性回归算法

文章目录线性回归线性回归的理解损失函数简单线性回归封装线性回归算法线性回归算法在sklearn中调用线性回归算法向量化运算线性回归模型中的误差均方误差 MSE均方根误差平均绝对误差调用sklearn中的均方根误差和平均绝对误差函数R squared error &#xff08;常用&#xff09;…

结构光相机国产、非国产统计参数对比分析

结构光相机国产、非国产统计参数对比分析 1. Kinect v1 Kinect v1深度相机拥有一个RGB彩色摄像头&#xff0c;一个红外线CMOS摄像机和一个红外发射器。相机的红外线CMOS摄像机和红外发射器以左右水平的方式分布。该相机采用的是以结构光为基础进行改进后的光编码&#xff08;…