ZOJ 3551 Bloodsucker(概率)
来源:互联网 发布:js insertbefore 编辑:程序博客网 时间:2024/05/16 10:30
Description
有n-1个人和一个吸血鬼,每天都会两个人相遇,如果这两个人同类则什么都不会发生,如果一个人遇见了一个吸血鬼则这个人有p的概率转变为吸血鬼,问所有人都转化为吸血鬼的期望天数
Input
第一行为一整数T表示用例组数,每组用例包括一个整数n表示人数(n-1个人和一个吸血鬼)和一个浮点数p表示人和吸血鬼相遇时人转化为吸血鬼的概率 (1 ≤ n < 100000, 0 < p ≤ 1)
Output
输出所有人转化为吸血鬼的期望天数,结果保留小数点后三位
Sample Input
1
2 1
Sample Output
1.000
Solution
每天至多有一个人转化为吸血鬼,考虑第i个人转化为吸血鬼的期望天数D[i],那么所有人转化为吸血鬼的期望天数ans=D[1]+D[2]+…+D[n-1],设第i个人转化为吸血鬼的概率为p[i],则第i个人转化为吸血鬼服从几何分布,故D[i]=1/p[i],而p[i]=p*i*(n-i)/(n*(n-1)/2),所以D[i]=n*(n-1)/(2*p*i*(n-i)),那么我们就可以在O(n)的时间内得到ans值
Code
#include<stdio.h>int main(){ int t,n;double p,ans; scanf("%d",&t); while(t--) { scanf("%d%lf",&n,&p); ans=0; for(int i=1;i<n;i++) ans+=1.0*n*(n-1)/(2*p*i*(n-i)); printf("%.3lf\n",ans); } return 0;}
0 0
- ZOJ 3551 Bloodsucker(概率)
- ZOJ 3551 Bloodsucker (概率DP)
- ZOJ 3551 Bloodsucker(概率dp啊 )
- ZOJ 3551 Bloodsucker 概率DP
- [zoj 3551]Bloodsucker[概率DP]
- zoj 3551 Bloodsucker (概率dp)
- ZOJ 3551 Bloodsucker 概率DP
- zoj 3551 Bloodsucker 概率DP
- ZOJ 3551 Bloodsucker(概率DP)
- ZOJ 3551 Bloodsucker [概率DP]
- zoj 3551 Bloodsucker
- ZOJ 3551 Bloodsucker
- ZOJ 3551 Bloodsucker 题解
- ZOJ 3551 Bloodsucker
- ZOJ3551 Bloodsucker(概率dp)
- zoj3551 Bloodsucker//概率&dp
- ZOJ3551:Bloodsucker(概率DP)
- zoj 3351 Bloodsucker
- Halcon模板匹配实例-1
- 详解PHP_EOL
- 【editplus经常用的快捷键】Editplus 选中一行ctrl+r,Edit 合并行 Ctrl+Shift+J 合并选定行 删除当前行
- AR/VR研究框架——迎接AR元年
- 【吐槽】为什么用户名不能换啊!
- ZOJ 3551 Bloodsucker(概率)
- 将input type="file" 类型的图片文件转成base64
- 常用颜色值
- freenode irc 如何注册
- Linux下显示目录的方法
- linux下搭建mrbs会议室预定管理系统
- Oracle中用exp/imp命令参数详解
- 图形绘图库 科学数据可视化
- android红米等关于读取本地文件夹图片获取路径的问题的解决