蒙特卡洛算法求圆周率

遇到一个算法面试题,要求通过程序求出圆周率。作为数学渣的我,瞬间懵逼。
于是翻看其他大佬们对于圆周率的计算方式,看到一个比较好理解的算法:蒙特卡洛算法。
圆与外接正方形
如上图,外接正方形的面积S1 = (2R)^2 = 4 * R^2;圆的面积S2 = PI * R^2。
因此,一个随机点A(x,y|x∈[-1,1],y∈[-1,1]),P(落到圆里的概率) = S2 / S1 = PI / 4;
因此,圆周率 PI = 4 * P(落到圆里的概率)。
而当圆的半径为1时,圆上所有点到圆心的长度都不会超过1;
因此设圆心为O,向量OA的模长 √(x^2 + y^2) <= 1;
也就是说,当 x^2 + y^2 <= 1 时,就表示当前随机点A是落在圆里的。
综上所述,只要统计足够多的次数,就能大致推算出圆周率 PI 的值了。

/**
 * Classname: Test
 * Date: 2020/05/31 18:56
 */
public class Test {
   
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值