hdu4554 A Famous Game 概率期望

题面

题意:n个球,2种颜色,可能有0~n个红球,每种情况的概率相同。现在从箱子里取出了$p$个球,其中有$Q$个是红球,问现在再取一个球是红球的概率为多少?

题解:因为0 ~ n的概率相同,所以每个球是红色的概率不互相独立。设A表示下一个球是红色这个事件,B表示取了$p$个球,有$Q$个红球这个事件,$N_{k}$表示一开始袋子里有$k$个红球。那么我们就是要求$P(A | B)$
$$P(A|B) = \frac{P(AB)}{P(B)} = \frac{\sum_{k = 0}^{n} P(AB | N_{k}) P(N_{k})}{\sum_{k = 0}^{n}P(B | N_{k}) P(N_{k})}$$
$$= \frac{\sum_{k = 0}^{n} P(A | BN_{k}) P(B | N_{k}) P(N_{k})}{\sum_{k = 0}^{n} P(B | N_{k})}$$
分析可知:$$P(A | BN_{k}) = \frac{k - Q}{N - p}, P(N_{k}) = \frac{1}{N + 1}, P(B | N_{k}) = \frac{C_{k}^{Q} C_{N - k}^{p - Q}}{C_{N}^{p}}$$
代入原式:
$$\frac{\sum_{k = 0}^{N} \frac{k - Q}{N - p} \frac{C_{k}^{Q} C_{N - k}^{p - Q}}{C_{N}^{p}} \frac{1}{N + 1}}{\sum_{k = 0}^{N} \frac{C_{k}^{Q} C_{N - k}^{p - Q}}{C_{N}^{p}}\frac{1}{N + 1}}$$
$$=\frac{\sum_{k = 0}^{N} \frac{k - Q}{N - p} \frac{C_{k}^{Q} C_{N - k}^{p - Q}}{C_{N}^{p}} }{\sum_{k = 0}^{N} \frac{C_{k}^{Q} C_{N - k}^{p - Q}}{C_{N}^{p}}}$$
$$=\frac{\sum_{k = 0}^{N} (k - Q) \frac{C_{k}^{Q} C_{N - k}^{p - Q}}{C_{N}^{p}} }{\sum_{k = 0}^{N} (N - p) \frac{C_{k}^{Q} C_{N - k}^{p - Q}}{C_{N}^{p}}}$$
先尝试对分子进行化简:
$$\frac{k!}{Q!(k - Q)!} \frac{(N - k)!}{(p - Q)! (N - k - p + Q)!}(k - Q)$$
观察到第一个分式的分母可以和$(k - Q)$约掉得到$\frac{k!}{Q!(k - Q - 1)!}$.
如果能把这个式子也变成组合数的形式,会更有利于化简,观察到$(k - Q - 1)!$其实对应的是$C_{k}^{Q + 1}$,因此我们尝试把这个部分表示为$C_{k}^{Q + 1}$,那么下面就要多乘一个$Q + 1$,相当于给整个式子除了一个$Q + 1$,因此我们在末尾再把$Q + 1$乘回来,于是得到原式为:
$$\frac{\sum_{k = 0}^{N} C_{k}^{Q + 1} C_{N - k}^{p - Q} (Q + 1)}{\sum_{k = 0}^{N} C_{k}^{Q} C_{N - k}^{p - Q}(N - p)}$$
$$\frac{\sum_{k = 0}^{N} C_{k}^{Q + 1} C_{N - k}^{p - Q}}{\sum_{k = 0}^{N} C_{k}^{Q} C_{N - k}^{p - Q}} \frac{Q + 1}{N - p}$$
因为有$$\sum_{k = 0}^{s} C_{k}^{n} C_{s - k}^{m} = C_{s + 1}^{n + m + 1}$$

原因:可以看做是有$s + 1$个物品,要从里面取$n + m + 1$个,这个式子就相当于是在枚举第$n + 1$个取走了第$k + 1$。然后再在前$k$个中取$n$个,在后$s + 1 - k - 1 = s - k$中取$m$个。

所以对原式化简得到:$\frac{Q + 1}{p + 2}$

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 #define R register int 
 4 
 5 void work()
 6 {
 7     double n, p, q; int tot = 0;
 8     while(scanf("%lf%lf%lf", &n, &p, &q) != EOF) 
 9         printf("Case %d: %.4lf\n", ++ tot, (q + 1) / (p + 2));
10 }
11 
12 int main()
13 {
14     freopen("in.in", "r", stdin);
15     work();
16     fclose(stdin);
17     return 0;
18 }
View Code

 

转载于:https://www.cnblogs.com/ww3113306/p/10186811.html

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

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

相关文章

计算机论文搜索技巧【二】

##善用谷歌学术 ####本文以“blockchain”为例 1.创建快讯 当你确定了研究方向时&#xff0c;订阅功能会主动推送相关文章&#xff0c;是被动输入的神器 2.善用“左栏”筛选条件 3.善用文章摘要下“图标”扩展思路 如何下载文章 未完待续…

java学习(128):map类

定义一个汽车类 import java.util.Date; public class Car {private String brand;//品牌private Date createDate;private int housepower;//马力private int speed;//速度public void setBrand(String brand) {this.brand brand;}public String getBrand() {return brand;}…

[From 1.1~1.2]CLR的执行模型

程序集&#xff08;assembly&#xff09;&#xff1a;程序集是抽象概念程序集是一个或多个模块/资源文件的逻辑性分组。其次&#xff0c;程序集是重用&#xff0c;安全性以及版本控制的最小单元。在CLR的世界中&#xff0c;程序集相当于“组件”。公式表达&#xff1a;程序集 …

java学习(129):hashmap的方法

import java.util.Date; public class Car {private String brand;//品牌private Date createDate;private int housepower;//马力private int speed;//速度public void setBrand(String brand) {this.brand brand;}public String getBrand() {return brand;}public Date getC…

[Leedcode][JAVA][第999题][直接考虑题意]

【问题描述】 在一个 8 x 8 的棋盘上&#xff0c;有一个白色车&#xff08;rook&#xff09;。也可能有空方块&#xff0c;白色的象&#xff08;bishop&#xff09;和黑色的卒&#xff08;pawn&#xff09;。它们分别以字符 “R”&#xff0c;“.”&#xff0c;“B” 和 “p”…

计算闰年

#22 计算闰年 能被4整除 但不能被100整除&#xff0c;或者能被400整除 result[] for i in range(1980,2019):if (i%40 and i%100!0) or (i%4000):result.append(i) print(result) 转载于:https://www.cnblogs.com/xiaoxiao075/p/10191584.html

java学习(130):treemap类

public class Department {private String code;//部门编号private String name;//部门名字private int quanity;//部门人员数量public void setCode(String code) {this.code code;}public String getCode() {return code;}public void setName(String name) {this.name nam…

[Leedcode][JAVA][第914题][最大公约数]

【问题描述】 给定一副牌&#xff0c;每张牌上都写着一个整数。此时&#xff0c;你需要选定一个数字 X&#xff0c;使我们可以将整副牌按下述规则分成 1 组或更多组&#xff1a;每组都有 X 张牌。 组内所有的牌上都写着相同的整数。 仅当你可选的 X > 2 时返回 true。示例 …

java学习(131):hashtable

import java.util.Hashtable;//hashtable public class test70 {public static void main(String[] args){Hashtable htnew Hashtable();ht.put("k0","歌谣");ht.put("k1","小白");ht.put("k2","小红");//ht.put…

如何快速在Github找到你想要的东西

众所周知 Github是全球最大的xx交友平台&#xff0c;虽然被收购了。但是不并没有什么影响。 使用Git可以做很多事&#xff0c;在这里不再缀述&#xff0c;上面的资源也是多种多样&#xff0c;应有尽有 对于这样一个平台&#xff0c;我们想快速找到自己需要的资源有什么好办法。…

[Leedcode][JAVA][第820题][字典树][Set]

【问题描述】 给定一个单词列表&#xff0c;我们将这个列表编码成一个索引字符串 S 与一个索引列表 A。例如&#xff0c;如果这个列表是 ["time", "me", "bell"]&#xff0c;我们就可以将其表示为 S "time#bell#" 和 indexes [0, 2…

java学习(132):hashtable使用map替代实体数据

import java.util.*;public class test71 {public static void main(String[] args){Scanner innew Scanner(System.in);System.out.println("请输入学生的信息");List syuListnew ArrayList();//存储所有学生for(int i1;i<3;i){HashMap stuMapnew HashMap();Syst…

spring----06 更多DI知识

一. 延迟初始化 延迟初始化也叫做惰性初始化&#xff0c;指不提前初始化Bean&#xff0c;而是只有在真正使用时才创建及初始化Bean。配置方式很简单只需在<bean>标签上指定 “lazy-init” 属性值为“true”即可延迟初始化Bean Spring容器会在创建容器时提前初始化“singl…

[Leedcode][JAVA][第1162题][BFS]

【问题描述】 你现在手里有一份大小为 N x N 的『地图』&#xff08;网格&#xff09; grid&#xff0c;上面的每个『区域』&#xff08;单元格&#xff09;都用 0 和 1 标记好了。其中 0 代表海洋&#xff0c;1 代表陆地&#xff0c;你知道距离陆地区域最远的海洋区域是是哪一…

java学习(133):泛型

public class Employee {private String name;private String ags;public void setName(String name) {this.name name;}public String getName() {return name;}public void setAgs(String ags) {this.ags ags;}public String getAgs() {return ags;} }测试类 import java.…

centos7默认网卡配置文件_CentOS7中网络配置详解

一、前言本来准备写一些网络配置工具的使用&#xff0c;后来想了想(其实还是为了偷懒)&#xff0c;网上关于nmcli工具的使用文章不多&#xff0c;所以写一下CentOS7中的nmcli工具的简单使用和CentOS7中一些网络属性配置的相关变化。二、CentOS7网络方面的变化很多朋友刚接触到C…

Golang 学习资料

资料 1.How to Write Go Code https://golang.org/doc/code.html 2.A Tour of Go https://tour.golang.org/list 3.Effective Go https://golang.org/doc/effective_go.html 4.Visit the documentation page for a set of in-depth articles about the Go language and its lib…

【软考】[信息安全工程师]

【背景】 有一定的基础&#xff0c;于2019年5月的考试上岸&#xff0c;复习了两周左右。奥里给&#xff01; 【备考资料】 【参考网站】 信管网 http://www.cnitpm.com/aq/ 月梦工作室 https://www.moondream.cn/ 含历年试题以及参考答案 【参考教材】 信息安全工程师五天…

java学习(134):泛型通配符的使用

import java.util.ArrayList; import java.util.List;//泛型通配符的使用 public class test73 {public static void main(String[] args){List<Integer> intListnew ArrayList<Integer>();intList.add(new Integer(100));intList.add(new Integer(200));List<?…

java dictionary遍历_遍历 Dictionary,你会几种方式?

一&#xff1a;背景1. 讲故事昨天在 StackOverflow 上看到一个很有趣的问题&#xff0c;说: 你会几种遍历字典的方式&#xff0c;然后跟帖就是各种奇葩的回答&#xff0c;挺有意思&#xff0c;马上就要国庆了&#xff0c;娱乐娱乐吧&#xff0c;说说这种挺无聊的问题&#x1f6…