问题:

一副扑克牌,除去大小王后共52张牌,随机从中抽八张牌,问八张牌的和最有可能是多少?

分析:

这52张牌,其实就是数字 1 2 3 。。。13, 每个数字出现4次。随机抽出8个数,问组成的和最有可能是多少?

很快想到了2种方法:

1.根据 大数定理 ,多次模拟抽牌,求和,看和的分布情况

2.在所有的C(52,8)种情况中,求出所有89(12-100)种情况和的组合数

解法1:

首先生成一副扑克牌,放入list中,每次随机取出一张牌后,list remove该元素,代码如下:

 package test;

 import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map; public class LargeNumbersTest { public static int getSum() {
//生成一副扑克牌,放入list
List<Integer> list=new ArrayList<Integer>();
for(int i=1;i<14;i++){
list.add(i);
list.add(i);
list.add(i);
list.add(i);
} int[] a=new int[8];
for(int i=0;i<8;i++){
int random=(int)(Math.random()*list.size());
//随机取出一张牌,并在list集合中去除对应的数
a[i]=list.get(random);
list.remove(random);
}
int sum=0;
for(int i=0;i<a.length;i++){
sum+=a[i];
}
return sum;
}
public static void main(String[] args) {
Map<Integer,Integer> map=new HashMap<Integer, Integer>();
//多次重复试验
for(int i=0;i<1000000;i++){
int key=getSum();
//试验结果存入map中,记录出现的次数
if(map.keySet().contains(key)){
map.put(key, map.get(key)+1);
}else{
map.put(key, 1);
}
}
//输出map集合,本来想写一个按值排序的方法,搜了一下,太麻烦,果断放弃,改用excel处理结果
for(Integer key:map.keySet()){
System.out.println(map.get(key)+"\t"+key);
}
}
}

运行5次后,输出结果在excel中排序,如下:

可以看出,和是56的结果最多,大概39800,(只要三万九千八,求和结果带回家。。。),根据大数定理,估计和最可能的数是 56 ,概率约等于 0.0398,

但是,和为57、55出现的次数也比较接近 56 ,是不是概率相等呢?

我们求一下每种情况的准确概率(大数定理只能估算概率),请看解法2。

解法2:

模拟计算机抽牌的每一种情况,求出每一种情况下的和。

1.如果按照每张牌的点数分类的话,每次抽牌都要考虑这张牌的点数 在本次抽牌中 出现的次数,太麻烦,所以对每张牌进行编号(0-51),

问题转化为:在0-51中取出8个不同的数字,并对这8个数字代表的点数 求和。

2.8个数字,8个变量,8次循环,感觉很low啊,不过我没想到好的办法,就先这样吧,希望大家找到好的办法能分享给我。

代码如下:

 package test;

 import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map; public class PokerTest {
public static void main(String[] args) {
//生成一副扑克牌,放入list
List<Integer> list=new ArrayList<Integer>();
for(int i=1;i<14;i++){
list.add(i);
list.add(i);
list.add(i);
list.add(i);
}
int count=0;
Map<Integer,Integer> map=new HashMap<Integer, Integer>();
//模拟每一种抽牌结果,low到爆的8次循环
for(int a1=0;a1<45;a1++){
for(int a2=a1+1;a2<46;a2++){
for(int a3=a2+1;a3<47;a3++){
for(int a4=a3+1;a4<48;a4++){
for(int a5=a4+1;a5<49;a5++){
for(int a6=a5+1;a6<50;a6++){
for(int a7=a6+1;a7<51;a7++){
for(int a8=a7+1;a8<52;a8++){
int sum=list.get(a1)+list.get(a2)
+list.get(a3)+list.get(a4)
+list.get(a5)+list.get(a6)
+list.get(a7)+list.get(a8);
//记录抽牌总次数
count++;
//抽牌结果记录到map中,并记录次数
if(map.keySet().contains(sum)){
map.put(sum, map.get(sum)+1);
}else{
map.put(sum, 1);
}
}
}
}
}
}
}
}
}
for(Integer key:map.keySet()){
System.out.println(map.get(key)+"\t"+key);
}
System.out.println("count===="+count);
} }

结果依然是输出到excel中处理,

首先  count====752538150  。。。。。超乎想象的大,看来解法一中的循环次数还是太少。

用C(52,8)计算了下,这个结果没错

概率计算结果

得到和为 56 的概率为 0.039791 ,和解法1中估算的值 0.0398 比较接近了

和为55、57的概率同为 0.039601 ,与和为 56 的概率差距真的很小了,

就这样了

[java,2018-06-26] 扑克牌抽牌求和问题的更多相关文章

  1. 2018.06.26「TJOI2018」数学计算(线段树)

    描述 小豆现在有一个数 xxx ,初始值为 111 . 小豆有 QQQ 次操作,操作有两种类型: 111 $ m$ : x=x×mx=x×mx=x×m ,输出 xxx modmodmod MMM : ...

  2. 2018.06.26 Dominator Tree--支配树

    在学习支配树之前,请保证已经会写lca(tarian求法) 简介 支配树是什么?支配树能干什么? 对于一个DAG" role="presentation" style=& ...

  3. 2018.06.26 NOIP模拟 号码(数位dp)

    题目背景 SOURCE:NOIP2015-GDZSJNZX(难) 题目描述 Mike 正在在忙碌地发着各种各样的的短信.旁边的同学 Tom 注意到,Mike 发出短信的接收方手机号码似乎都满足着特别的 ...

  4. 2018.06.26 NOIP模拟 纪念碑(线段树+扫描线)

    题解: 题目背景 SOURCE:NOIP2015−GDZSJNZXSOURCE:NOIP2015-GDZSJNZXSOURCE:NOIP2015−GDZSJNZX(难) 题目描述 2034203420 ...

  5. http://stormzhang.com/opensource/2016/06/26/android-open-source-project-recommend1/

    转载自:http://stormzhang.com/opensource/2016/06/26/android-open-source-project-recommend1/ 推荐他的所有博文~ 图片 ...

  6. 2018.10.26 浪在ACM 集训队第二次测试赛

    2018.10.26 浪在ACM 集训队第二次测试赛 整理人:苗学林 A海港 参考博客:[1]:李继朋https://www.cnblogs.com/violet-acmer/p/9859006.ht ...

  7. 用python实现一个小游戏——抽牌

    想要实现一个抽牌的功能,有很多种实现方法,这时候我们创造一个对象,通过内置方法来完成这个功能: # Author:Zhang Zhao # -*-coding:utf-8-*- from collec ...

  8. Insider Dev Tour(2018.06.28)

    时间:2018.06.28地点:北京金茂万丽酒店

  9. OPPO Developers Conference(2018.12.26)

    时间:2018.12.26地点:北京国家会议中心

随机推荐

  1. 设计简单的VB程序

    1.模拟对话程序 [程序源码] Option Explicit Private Sub Command1_Click() Text2.Text = "" Text1.Text = ...

  2. 网络编程一定要看过的socket大山

    python已经可以做很多的东西了.但是要想要和别人互联互通就会涉及到一个关键的模块socket!值得一提的是,其实socket不是python独创的一种模块,而是任何语言都会有的一个部分!自己的程序 ...

  3. Netty 线程模型

    一.线程模型概述 线程模型表明了代码的执行方式.从最开始的使用单线程,后来出现了多线程,之后是线程池.当有要执行的任务时,任务会被传到线程池,从线程池中获得空闲的线程来执行任务,执行完了后会将线程返回 ...

  4. Scrapy 代理IP

    Scrapy 代理IP 一.Scarpy使用代理IP 1.在setting.py 配置 代理服务器IP 2.在middlermares.py 配置 downloadmiddlermare(下载中间件) ...

  5. supervisor支持python虚拟环境venv

    在项目中使用supervisor时,如何在虚拟环境下启动一直存在些小问题. 比如我要写 Cesi程序的监听,我是手动安装的执行之前 要先加载环境source venv/bin/activate 所以写 ...

  6. KiCad 一款强大的 BOM 和 装配图生成插件

    KiCad 一款强大的 BOM 和 装配图生成插件 可以生成 BOM 和在线的图形. https://github.com/openscopeproject/InteractiveHtmlBom In ...

  7. 剑指offer 4.树 重建二叉树

    题目描述 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7, ...

  8. Jquery 一个页面单个倒计时 实现

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  9. MQTT研究之EMQ:【JAVA代码构建X509证书【续集】】

    openssl创建私钥,获取公钥,创建证书都是比较简单的,就几个指令,很快就可以搞定,之所以说简单,是因为证书里面的基本参数配置不需要我们组装,只需要将命令行里面需要的几个参数配置进去即可.但是呢,用 ...

  10. 【python】python打包生成的exe文件运行时提示缺少模块

    事情是这样的我用打包命令:pyinstaller -F E:\python\clpicdownload\mypython.py打包了一个exe程序,但是运行时提示我缺 少bs4模块然后我就去查pyin ...