题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=4465

题目意思:

有两个箱子,每个箱子装有N个糖果

打开第一个箱子的概率是P,另外一个就是1-P

当小明打开一个箱子的时候发现有糖果就会吃掉

有一天,小明打开其中的一个箱子,发现没有糖果了,求另外一个箱子的糖果数量的期望

这个公式其实是很好推的,枚举另外一个箱子剩余的数量来算就OK

这里的n经过了+1处理,这样我们枚举没有拿空的那个箱子里面拿了i个,那么剩下的就是n-i-1个

算概率的话,就是在前面的n+i-i次中我要在前面把拿空的箱子中拿n-1次再乘以概率p^n放,为什么前面是n-1,后面又是n呢?

因为最后一次一定要拿空的这个才可以,同理如果是另一个箱子

但是在算的时候不好算,因为要么是p^n后太小,要么是前面的组合数太大

所以只能边组合边乘

每次组合数可以用之前一个*(N+i-1)/i得到,为了避免爆double,

当数大于N(因为最终结果不可能大于N)的时候,乘以概率来减小,记录乘了多少次概率,最后算的时候少乘。

下面上代码:

#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std; const double eps = 1e-12; double fun(double s,double p,int n)
{
while(n)
{
if(s<eps)
return 0;
if(n&1)
s*=p;
n = n>>1;
p = p*p;
}
return s;
} int main()
{
int n;
double p;
int ca = 1;
while(~scanf("%d%lf",&n,&p))
{
double tmp1,tmp2;
tmp1 = tmp2 = 1;
double ans = 0;
n++;
int d=0;
for(int i=0;i<n;i++)
{
if(i)
{
tmp1 = tmp1*(1-p)*(n+i-1)/i;
tmp2 = tmp2*(p)*(n+i-1)/i;
while(tmp1>n || tmp2>n)
{
tmp1 = tmp1*p;
tmp2 = tmp2*(1-p);
d++;
}
}
ans += fun((n-i-1)*tmp1,p,n-d);
ans += fun((n-i-1)*tmp2,1-p,n-d);
}
printf("Case %d: %.6f\n",ca++,ans);
}
return 0;
}

除了这种方法以外,还有一种方法,神方法

就是在计算的时候会出现p^n这一步,太小,那么我们可以利用ln把n拿下来,然后再用e^n拿回去

具体见代码:

#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
int main()
{
int n;
double p;
double p1,p2,s1,s2;
int ca = 1; while(~scanf("%d%lf",&n,&p))
{
double c = 0;
double ans = 0;
p1 = log(p);
p2 = log(1-p); //exp之后就是p^(n+1) or (1-p)^(n+1)
s1 = (n+1)*p1;
s2 = (n+1)*p2; for(int i=0;i<n;i++)
{
if(c+s1>-30 || c+s2>-30)//这一步一定要加,计算没意义,还会导致TLE
ans += (exp(c+s1)+exp(c+s2))*(n-i);
c+=log(n+i+1)-log(i+1);
s1+=p2;
s2+=p1;
}
printf("Case %d: %lf\n",ca++,ans);
} return 0;
}

Candy----HDU4465----数学题的更多相关文章

  1. HDU4465 Candy

    Candy Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  2. [LeetCode] Candy 分糖果问题

    There are N children standing in a line. Each child is assigned a rating value. You are giving candi ...

  3. Leetcode Candy

    There are N children standing in a line. Each child is assigned a rating value. You are giving candi ...

  4. LeetCode 135 Candy(贪心算法)

    135. Candy There are N children standing in a line. Each child is assigned a rating value. You are g ...

  5. [LeetCode][Java]Candy@LeetCode

    Candy There are N children standing in a line. Each child is assigned a rating value. You are giving ...

  6. 【leetcode】Candy(hard) 自己做出来了 但别人的更好

    There are N children standing in a line. Each child is assigned a rating value. You are giving candi ...

  7. ytu 2558: 游起来吧!超妹!(水题,趣味数学题)

    2558: 游起来吧!超妹! Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 7  Solved: 3[Submit][Status][Web Board ...

  8. 【leetcode】Candy

    题目描述: There are N children standing in a line. Each child is assigned a rating value. You are giving ...

  9. Codeforces Round #229 (Div. 2) C. Inna and Candy Boxes 树状数组s

    C. Inna and Candy Boxes   Inna loves sweets very much. She has n closed present boxes lines up in a ...

  10. [LintCode] Candy 分糖果问题

    There are N children standing in a line. Each child is assigned a rating value. You are giving candi ...

随机推荐

  1. Android Studio git ignore

    # Built application files *.apk *.ap_ # Files for the Dalvik VM *.dex # Java class files *.class # G ...

  2. DB2 相关操作

      查看数据库版本:db2level DB21061E  Command line environment not initialized. windows命令行下,需要先调用db2cmd,或者DB2 ...

  3. 利用JSP编程技术实现一个简单的购物车程序

    实验二   JSP编程 一.实验目的1. 掌握JSP指令的使用方法:2. 掌握JSP动作的使用方法:3. 掌握JSP内置对象的使用方法:4. 掌握JavaBean的编程技术及使用方法:5. 掌握JSP ...

  4. Oracle EBS-SQL (SYS-13):查询DBA在系统中的打Patch的信息.SQL

    查询DBA在系统中的打补丁信息 1. select * from ad_patch_drivers          /*查看已经打了哪些Patch*/ 2. select * from ad_pat ...

  5. Oracle EBS-SQL (SYS-6):sys_在线用户职责查询.sql

    /*线用户查询-1*/ SELECT FSAV.USER_NAME,FU.DESCRIPTION,FSAV.RESPONSIBILITY_NAME,FSAV.USER_FORM_NAME,FSAV.L ...

  6. Android扫描SD卡中的文件

    当android的系统启动的时候,系统会自动扫描sdcard内的多媒体文件,并把获得的信息保存在一个系统数据库中,以后在其他程序中如果想要访问多媒体文件的信息,其实就是在这个数据库中进行的,而不是直接 ...

  7. http://docs.aliyun.com/#/rds/best-practices/collocation&security

    http://docs.aliyun.com/#/rds/best-practices/collocation&security

  8. Spring构造器注入、set注入和注解注入

    记得刚开始学spring的时候,老师就反复的提到依赖注入和切面,平常的java开发中,在某个类中需要依赖其它类的方法,则通常是new一个依赖类再调用类实例的方法,这种方法耦合度太高并且不容易测试,sp ...

  9. JavaScript之面向对象学习六原型模式创建对象的问题,组合使用构造函数模式和原型模式创建对象

    一.仔细分析前面的原型模式创建对象的方法,发现原型模式创建对象,也存在一些问题,如下: 1.它省略了为构造函数传递初始化参数这个环节,结果所有实例在默认的情况下都将取得相同的属性值,这还不是最大的问题 ...

  10. SQL学习之去重复查询

    下面是一张表的数据