文档章节

java计算圆周率

z
 zongze30
发布于 2015/02/13 10:14
字数 650
阅读 32
收藏 0

一、理论篇

1. 数学公式

圆面积公式:π*r*r,其中π为圆周率,r为圆半径;

正方形面积公式:s*s,其中s为边长;

勾股定理:a*a + b*b = c*c,其中a/b分别为直角三角形的两个直角边,c为斜边。

2. 计算方法

考虑下图,边长为r的正方形内嵌了一个以r为半径的1/4圆。

image

InsideCircle面积 = 以r为半径的圆面积 / 4 = π*r*r/4

正方形面积 = r*r

所以, InsideCircle面积 / 正方形面积 = (π*r*r/4) / (r*r) = π/4

面由线组成,线由点组成。因此,如果有若干点均匀落入到正方形中,那么落入InsideCircle的点的个数占总数的比率也将会是π/4,由此将会统计出π的值。

 

二、实战篇

1. 散弹枪计算

具体方式为:制作一个如上图一样正方形木板,用散弹枪对着它一顿乱扫,最后统计弹孔个数和落点,从而得出π的值。

事实上,真的有研究人员做过这个脑洞大过黑洞的实验,他们在 30857 个样本中得到了 3.13 这个还算不错的结果。

详见:http://www.techug.com/compute-pi-with-gun

2. Java随机数计算

作为一个码农,当然玩不起散弹枪这种高级玩具,那么接下来就以代码来玩一把。

具体思路是这样的:r直接取值为1.0,还需要定义一个落在正方形中的所有点的个数PointNumber,每一个点都有一个坐标(x,y),x,y取值为0.0-1.0,利用Java随机数生成每个点,然后用勾股定理判断该点是落在圆内还是圆外,并统计落在圆内的点的个数InsideCircleNumber,那么π=InsideCircleNumber/PointNumber*4。当然,如果只计算一次的话,可能误差会较大,可以再增加一个计算次数CalcTimes,然后求平均值。

按照这样的思路的计算结果如下:

PointNumber

CalcTimes

π

最接近π的值

10000

10000

3.141617279999959

3.1416

100000

10000

3.1415569599999684

3.1416

1000000

10000

3.1415845499999953

3.141592

10000000

10000

3.1415924761886806

3.1415928

附源代码:

package com.test.pai;
import org.apache.commons.lang.math.RandomUtils;
public class CalcPai           
{            
    public static boolean inCircle(double x, double y)            
    {            
        return (y <= Math.sqrt(1 - x * x));            
    }
    public static double CalcPaiByPointNumber(long num)           
    {            
        double inCircleNum = 0.0;            
        for (long i = 0; i < num; i++)            
        {            
            if (CalcPai.inCircle(RandomUtils.nextDouble(), RandomUtils.nextDouble()))            
            {            
                inCircleNum++;            
            }            
        }
        double pai = inCircleNum * 4 / num;
        return pai;           
    }
    public static void main(String[] args)           
    {            
        double realPai = 3.14159265;            
        CurrResult currResult = new CurrResult(0.0, realPai, 0.0);            
        long times = 10000;            
        long num = 1000000;            
        for (long i = 1; i <= times; i++)            
        {
            double pai = CalcPai.CalcPaiByPointNumber(num);           
            currResult.setTotalPai(currResult.getTotalPai() + pai);            
            double diff = Math.abs(realPai - pai);            
            if (diff < currResult.getDifference())            
            {            
                currResult.setCurrPai(pai);            
                currResult.setDifference(diff);            
            }
            System.out.println("No." + i + "/" + times + "\t" + pai + "\t" + currResult.getCurrPai() + "\t"           
                    + currResult.getTotalPai() / i);            
        }
    }
}

转自:http://blog.csdn.net/xuejiaqiang88/article/details/43791703

本文转载自:http://blog.csdn.net/xuejiaqiang88/article/details/43791703

共有 人打赏支持
z
粉丝 0
博文 7
码字总数 1170
作品 0
石家庄
私信 提问
3月14日圆周率日—使用并行计算求圆周率π

关于圆周率大家再熟悉不过了: 我们从课本上学习到早在一千多年前,祖冲之将圆周率计算到3.1415926到3.1415927之间…计算机诞生后,计算圆周率被用来检测计算机的硬件性能,昼夜燃烧cpu看会不...

fourinone
2013/03/14
0
25
hadoop 伪分布式安装步骤

操作系统 centos7 java verson : jdk1.8.0_151 hadoop version : hadoop-2.8.1 1、把安装包放到 opt文件夹下面。并进行解压。 cd /opt tar -zxvf hadoop-2.8.1 2、配置jdk、hadoop文件路径...

西行侠客
2018/01/23
0
0
利用javax.tools动态编译执行java代码

 本文永久地址:https://my.oschina.net/bysu/blog/1552933 inkfish原创,请勿商业性质转载,转载请注明来源(http://blog.csdn.net/inkfish )。   参考:使用 javax.tools 创建动态应用...

不最醉不龟归
2017/10/18
0
0
Oracle 领导下的 Java 长远发展战略

根据 Oracle 最新的 PPT “To Java SE 8 and Beyond”从 JDK 10 开始,Java 将拥有一个统一的类型体系,也就是任何类型都是对象,没有基本类型(primitives)了。上周 Oracle 技术的布道者 ...

虫虫
2012/03/31
5.1K
44
pvDuino上安装Java开发平台

Java是由Sun Microsystems公司于 1995年5月推出的Java面向对象程序设计语言(以下简称Java语言)和Java平台的总称。由James Gosling和同事们共同研发,并在1995年正式推出。用Java实现的Hot...

雨后的彩虹桥
2014/03/03
392
0

没有更多内容

加载失败,请刷新页面

加载更多

Quartz监听器Listerner

概述 Quartz的监听器用于当任务调度中你所关注事件发生时,能够及时获取这一事件的通知。Quartz监听器主要有JobListener、TriggerListener、SchedulerListener三种,顾名思义,分别表示任务、...

大笨象会跳舞吧
34分钟前
3
0
Call exception, tries=10, retries=35, started=38348 ms ago, cancelled=false, msg=pc-node1 row

写hbase的问题,2019-01-18 23:23:28,082 | INFO | [hconnection-0x6431d54d-shared--pool2-t5] | Call exception, tries=10, retries=35, started=38348 ms ago, cancelled=false, msg=p......

stys35
37分钟前
2
0
docker 安装portainer、gogs、redis、mongodb、es、rabbitmq、mysql、jenkins、harbor

1、准备三台虚拟机ip如下 编号 Ip 1 192.168.100.101 2 192.168.100.102 3 192.168.100.103 2、镜像应用编排 192.168.100.101 主要安装系统运维相关服务 192.168.100.102 主要安装mysql、mon...

北岩
47分钟前
6
0
storm 提交任务报SocketException错误及解决办法

提交任务爆错: org.apache.storm.thrift.transport.TTransportException: java.net.SocketException: Broken pipe (Write failed) ..... Caused by: org.apache.storm.thrift.transport.TTr......

jingshishengxu
51分钟前
1
0
值得收藏:一份非常完整的MySQL规范

一、数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命...

Java干货分享
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部