Hdu 4465 Candy (快速排列组合+概率)
题目链接:
题目描述:
有两个箱子,每个箱子有n颗糖果,抽中第一个箱子的概率为p,抽中另一个箱子的概率为1-p。每次选择一个箱子,有糖果就拿走一颗,没有就换另外一个箱子。问换箱子的时候,另外一个箱子中剩下糖果的期望值。
解题思路:
注意题目描述,其中任意一个箱子没有糖果,另一个箱子中剩下糖果个数的期望,而不是第一个箱子没有糖果。不是把其中一个箱子取空时,另一个箱子剩下糖果的期望,而是其中一个箱子取空再换另外一个箱子时,这个箱子的期望。
可以根据期望性质画出公式:ans = (n-i) * C(n+i,n) * (p^(n+1)*(1-p)^i + (1-p)^(n+1)*p^i) (0<=i<=n);新的问题又来了,C(n+i,n)由于n的原因可能会向上溢出,而p^(n+1)又可能会很小,然后向下溢出。可以分别对他们进行取log,log(C(n+i,n))范围变小,log(p^(n+1))变成负数,方便保存。
/*
******未处理精度的代码,推论严密美丽也无卵用********
期望公式Ε=∑ P * N p为概率 n为数量
P=p*C(n,m)*p^n*(1-p)^(m-n)
c(m,n)=c(m-1,n)*m/(m-n)
概率
m=0 p^(n+1)
m=1 p^(n+1)q
m=2 p^(n+1)q^2
*/
#include <cstdio>
#include <iostream>
#include <algorithm>
using namespace std; int main ()
{
int t, i, l = ;
double ans, p1, p2, res1, res2;
while (scanf ("%d %lf", &t, &p1) != EOF)
{
p2 = (1.0 - p1);
res1 = t * p1;
ans = ;
res2 = t * p2;
for (int i=; i<=t; i++)
{
ans *= p1 * p2 * (t + i) / i;
res1 += ans * (t - i);
res1 *= p1;
res2 += ans * (t - i);
res2 *= p2;
}
printf ("Case %d: %6lf\n", l++, res1+res2);
}
return ;
}
/*
取log处理精度问题,exp还原结果
*/
#include <cmath>
#include <cstdio>
#include <iostream>
#include <algorithm>
using namespace std;
const int maxn = ;
double Logf[maxn];
void init ()
{
Logf[] = ;
for (int i=; i<maxn; i++)
Logf[i] = Logf[i-] + log(i*1.0);
}
double C (int m, int n)
{
return Logf[m] - Logf[n] - Logf[m-n];
}
int main ()
{
int n, cas = ;
double p1, p2, ans;
init ();
while (scanf ("%d %lf", &n, &p1) != EOF)
{
ans = ;
p2 = 1.0 - p1;
p1 = log(p1);
p2 = log(p2);
for (int i=; i<n; i++)
{
ans += ((n-i) * exp(C(n+i, n) + (n+)*p1 + i*p2));
ans += ((n-i) * exp(C(n+i, n) + (n+)*p2 + i*p1));
}
printf ("Case %d: %f\n", cas++, ans);
}
return ;
}
Hdu 4465 Candy (快速排列组合+概率)的更多相关文章
- C++ STL next_permutation(快速排列组合)
		排列组合必备!! https://blog.csdn.net/bengshakalakaka/article/details/78515480 
- 2017ACM暑期多校联合训练 - Team 1  1006   HDU   6038   Function    (排列组合)
		题目链接 Problem Description You are given a permutation a from 0 to n−1 and a permutation b from 0 to m ... 
- hdu 4465 Candy(二次项概率)
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4465 参考博客:http://www.cnblogs.com/goagain/archive/2012 ... 
- HDU 4465 - Candy(概率与数学优化)
		2012成都Regional的B题,花了一个小时推出了式子,但是搞了好久发现都控制不了精度,后来突然想到组合数可以用log优化,改了之后就AC了 比较水的概率题 #include <stdio. ... 
- hdu 4465 Candy(2012 ACM-ICPC 成都现场赛)
		简单概率题,可以直接由剩余n个递推到剩余0个.现在考虑剩余x个概率为(1-p)的candy时,概率为C(2 * n - x, x) * pow(p, n + 1) *pow(1 - p, n - x ... 
- 牛客 Wannafly 挑战赛26D 禁书目录    排列组合 概率期望
		原文链接https://www.cnblogs.com/zhouzhendong/p/9781060.html 题目传送门 - NowCoder Wannafly 26D 题意 放一放这一题原先的题面 ... 
- hdu 4465 Candy (非原创)
		LazyChild is a lazy child who likes candy very much. Despite being very young, he has two large cand ... 
- hdu 5698 瞬间移动(排列组合)
		这题刚看完,想了想,没思路,就题解了 = = 但不得不说,找到这个题解真的很强大,链接:http://blog.csdn.net/qwb492859377/article/details/514781 ... 
- HDU 4465 Candy (数学期望)
		题意:有两个盒子各有n个糖(n<=2*105),每天随机选1个(概率分别为p,1-p),然后吃掉一颗糖.直到有一天打开盒子一看,这个盒子没有糖了.输入n,p,求此时另一个盒子里糖的个数的数学期望 ... 
随机推荐
- Go --- 设计模式(工厂模式)
			简易工厂主要是用来解决对象“创建”的问题.以下的例子取自<大话设计模式>中第一章,实现一个可扩展的“计算器”.当增加新的功能时,并不需改动原来已经实现的算法.由于是简易工厂,所以我们还是需 ... 
- pycharm查看代码注释的方法,代码编写日志及作者信息等
			竟然在边栏有个右键的快捷键.annotate可以查看代码书写日期及作者 鼠标悬停可以看到更加详细的时间等信息 原理应该是利用git blame 
- Download Software Top 10
			We are quite rich in terms of web browsers! Nevertheless, it's a bit surprising to know that even so ... 
- BC一周年B
			#include <cstdio> #include <iostream> #include <algorithm> #include <queue> ... 
- Xpath—解决这个问题的良药
			何为良药? 因为在XML中存在一些问题和缺陷,针对这些问题就产生了响应的解决方式.如: getElementById方法在解析XML时因为一些原因适不适合的: 首先XML中每一个元素节点不一定有id属 ... 
- 在windows cgywinportable上,通过运行linux命令,批量改动文件名。
			在windows cgywinportable上.通过运行linux命令.批量改动文件名. 实例:将当前文件夹下的全部文件名称加上.sql find ./ -type f -exec mv {} ' ... 
- [IT学习]华为全连接大会2017
			1.5分钟.3分钟.1分钟倒计时. 2.20万盏纽约街头的油灯接入电网,类比未来的公司IT系统会接入云? 3.1943年,全球只要5台计算机.不会的,但是会有5多云? 4.与航空业的联盟类比,云计算的 ... 
- oracle 导出导入不含数据的空库
			10g或之前,用exp导出,imp导入,带上rows=n参数 11g或以上,用expdp导出,impdp导入,带上CONTENT = METADATA_ONLY 参数 expdp带上此参数,不导出数据 ... 
- C项目实践--家庭财务管理系统
			1.功能需求分析 家庭财务管理系统给家庭成员提供了一个管理家庭财务的平台,系统可以对家庭成员的收入和支出进行增加,删除.修改和查询等操作,并能统计总收入和总支出.其主要功能需求描述如下: (1)系统主 ... 
- ios app抓包分析
			1 使用rvictl工具 这是mac下的一条命令.ios usb连mac,然后创建虚拟网络接口. 2 使用wireshark抓包 wireshark可以抓这个虚拟网络接口上的数据包. 
