在Python中找到随机数给定方程的期望值的程序
假设我们有一个数字n。考虑x=rand()modn,其中rand()函数随机均匀地生成0到10^100(包括两者)之间的整数。和
$$Y=\sqrt{x+\sqrt{x+\sqrt{x+\sqrt{x+...}}}}$$
我们必须找到Y的期望值。n的值将在1和5*10^6的范围内。
所以,如果输入像n=5,那么输出将是1.696
示例
让我们看看以下实现以获得更好的理解-
def solve(n):
err = 2235.023971557617
max_n = 5 * 10**6
pref = [0]
for i in range(1, 5 * 10**6):
pref.append(pref[-1] + (1 + (4 * i + 1)**0.5) * 0.5)
if n < max_n:
return pref[n - 1] / n
else:
total = (4 * (n - 1) + 5)**1.5 / 6 - 5**1.5 / 6 - err
ans = 0.5 + total / (2 * n)
return ans
n = 5
print(solve(n))输入
5输出结果
1.69647248786
热门推荐
10 祝女儿简短祝福语大全
11 大学新年祝福语简短创意
12 元旦适合的祝福语简短
13 朋友出远门祝福语简短
14 初六简短的祝福语
15 祝男孩生日祝福语简短
16 同事调离的祝福语简短
17 拜年红包的祝福语简短
18 妈妈生日祝福语简短励志