HDU4986 Little Pony and Alohomora Part I
发布日期:2021-06-29 05:37:38
浏览次数:3
分类:技术文章
本文共 661 字,大约阅读时间需要 2 分钟。
本题需要用到欧拉常数和递推。
题意:有n个箱子,n把钥匙随机的放在里面,问打开所有箱子的期望。
解析:每种情况都相当于一个循环的置换个数。
循环置换个数求解:那么考虑f[i]为i个箱子的情况,f[i + 1]要么就是放在最后多一个循环,要么就是插入中间循环个数不变,对应的转移为f[i + 1] = (f[i] + 1) / i + f[i] * (i - 1) / i 化简得到f[i] = f[i - 1] + 1 / i 。即f[n] = 1 + 1/2 + ...+ 1/ n,是个调和级数。
调和级数(即f(n))至今没有一个完全正确的公式,但欧拉给出过一个近似公式:(n很大时)
f(n)≈ln(n)+C+1/2*n
欧拉常数值:C≈0.57721566490153286060651209
代码:
#include#include #define N 1000005#define C 0.577215664901double a[N];int main(){ int n; a[1] = 1; for(int i = 2; i < N; i++) a[i] = a[i-1] + 1.0 / i; while(~scanf("%d", &n)){ double ans; if(n < N) ans = a[n]; else ans = log(n) + C + 1/(2*n); printf("%.4lf\n", ans); } return 0;}
转载地址:https://blog.csdn.net/zhj_fly/article/details/74486941 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
哈哈,博客排版真的漂亮呢~
[***.90.31.176]2024年04月09日 12时23分36秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
Linux下EasyPanel版本安装及升级
2019-04-29
raspberry pi(树莓派) + easycap d60 视频采集
2019-04-29
WebRTC
2019-04-29
rfc5766-turn-server NAT
2019-04-29
webrtc详细教程
2019-04-29
Android IOS WebRTC 音视频开发总结
2019-04-29
报表图表样式
2019-04-29
支付宝
2019-04-29
Android开发资源收集
2019-04-29
android模板图例
2019-04-29
树莓派网线直连
2019-04-29
复合材料培训(I第七期)
2019-04-29
复合材料生活中的应用
2019-04-29
ABAQUS复合材料(适合小白)
2019-04-29
ABAQUS高级案例解析
2019-04-29
人工智能药物研发
2019-04-29
【超级干货+福利】AIDD最全面的学习教程
2019-04-29
最新通知:AIDD与网络药理学资料大全
2019-04-29
Lammps分子动力学与第一性原理材料模拟及催化
2019-04-29
实习生小白的日常
2019-04-29