zoukankan      html  css  js  c++  java
  • 算法之美--1.蒙特卡洛方法计算pi

         

             基本思想: 利用圆与其外接正方形面积之比为pi/4的关系,通过产生大量均匀分布的二维点,计算落在单位圆和单位正方形的数量之比再乘以4便得到pi的近似值。样本点越多,计算出的数据将会越接近真识的pi(前提时样本是“真正的”随机分布)。

             蒙特卡罗(Monte Carlo)算法计算圆周率的主要思想:给定边长为R的正方形,画其内切圆,然后在正方形内随机打点,设点落在圆内的概为P,则根据概率学原理:    P = 圆面积 / 正方形面积 = PI * R * R / 2R * 2R = PI / 4。即 PI=4P。这样,当随机打点足够多时,统计出来的概率就非常接近于PI的四分之一了。

    #include <iostream>
    #include <ctime>
    using namespace std;
    
    int main()
    {
        const int MAX_TIMES = 20000000;
        srand(static_cast<unsigned int>(time(0)));
        
        int in=0;
        for (int i = 0; i < MAX_TIMES;i++)
        {
            double x = static_cast<double>(rand()) / RAND_MAX;
            double y = static_cast<double>(rand()) / RAND_MAX;
            if (x*x+y*y<=1.0)
            {
                in++;
            }
            if (i%(MAX_TIMES/100)==0)
            {
                cout << ".";
            }
        }
        double pi = 4.0*in / MAX_TIMES;
        cout << "
    PI=" << pi << endl;
        return 0;
    }

    实现了一下,感觉时间用的有点长。。。

    参考:http://www.cnblogs.com/kodoyang/p/MonteCarloMethod_PI.html

  • 相关阅读:
    Apache Kafka源码分析
    Apache Kafka源码分析
    Apache Kafka源码分析
    Apache Kafka源码分析
    如何保障流式处理的数据一致性
    Tuning Spark
    Java内存管理和垃圾回收
    Spark MLlib
    Win7系统与它的Virtualbox中安装的Ubuntu14.04共享信息的几种方法
    图片流量节省大杀器:基于CDN的sharpP自适应图片技术实践
  • 原文地址:https://www.cnblogs.com/ranjiewen/p/6105652.html
Copyright © 2011-2022 走看看