C++ 圆周率的几种求解方法

公众号:编程驿站

圆周率的常见几种求解算法,包括但不仅仅包含特卡洛模拟、割圆法和公式法。本文讲解这几种算法的实现流程。

1. 蒙特卡洛模拟算法

假设有一个半径为1的圆,如图所示。先绘制一个半径为1的圆。则图中阴影部分(1/4圆)的面积就等于π/4

1.png

再绘制出一个正方形,可以看出它的面积是 1 。通过这种方式,就能够获取到正方形面积和阴影部分面积的一个比例。如此可得到正方形和阴影面积的比例关系1:π/4。这是通过数学上提供的计算面积的公式,得到的一个比例。

另外的话呢,我们可以生成很多点。然后把它们随机、均均匀的把平铺到正方形里面去。这时候呢,我们可以认为这些点呢模拟出正方形的面积。另外我们需要计算出有哪些点落在了阴影部分。这种方式也能够获取到正方形和阴影部分面积的比例。这个比例和我们前面通过数学公式所求出的比例呢是一种恒等于的关系,我们利用这种恒等关系,就能够很轻松的获取到这个圆周率。

下面我们看一下这个代码应该如何实现?

第一步利用随机函数产生很多点(横坐标的值x和纵坐标的值y都在0~1之间)随机、均匀散满在正方形内。且统计出散落在阴影部分点的数量。获取正方形内点的数量和阴影部分点的数量的比例。显然,此比例和前面通过公式计算两者面积的比例具有恒等于关系。通过此关系便可计算出圆周率。

#include <iostream>
#include <cstdlib>
#include <ctime>
#include <cmath>
using namespace std;
int main(int argc, char** argv) {//随机种子srand( time(0) );double num=10000000;double circle=0;//random 伪随机数(算法)for(int i=1; i<num; i++) {double x= rand() / double(RAND_MAX);double y=rand() / double(RAND_MAX);if( x*x+y*y <=1 ) {circle++;}}double pi=4*circle /  num;cout<<pi;return 0;
}

2. 割圆法

例如,假设一个半径为1的圆,在圆中有一个内接6边形,如图所示。该内接六边形的弦长y=1,周长d=6*y1,则π的近似值pi=6*y/2=3
可以通过内接 12,24,48……正多边形,求出精度更高的圆周率。

如下图,把圆切割成六边形:根据等边三角形的特征,可知,六边形的边长y=1

2.png

如下图,把圆切割成正12边形。

3.png

因为ABD为直角三角形,可得AB2=AD2-BD2=1-1/4=3/4,所以AB=sqrt(3/4)

又因为BCD也为直角三角形,可得y2=BD2+CB2=1/4+(1-AB)2=1/4+1-2*sqrt(3/4)+3/4=2-sqrt(3)

所以:pi=6*sqrt( 2-sqrt(3) )

#include <bits/stdc++.h>
using namespace std;
int main () {int i,n,s=6;double y=1;cout<<"输入切割次数:"<<endl;cin>>n;for(int i=0; i<n; i++) {printf("第%d次切割,为%d边,PI=%.24f\n",i,s,s/2*sqrt(y));s*=2;//弦长的平方值 y=2-sqrt(4-y); }return 0;
}

3. 公式法

求解圆周率的公式常见的有如下三个:

3.1 公式一

4.png

本质是累乘问题,关键是找到参与累乘数字的之间的规律。这里有两种规律。

  • 通过观察可以发现,后一个分数的分母是前一个分数的分子加1,后一个分数的分子是前一个分数的分母加一。
    8.png

​ 代码实现

#include <bits/stdc++.h>
using namespace std;
int main(int argc, char** argv) {double res=1;int n;cin>>n;double fm=1,fz=2;for(int i=0;i<n;i++){res*=fz/fm;//先存储前一个分数的分母int t=fm;//后一个分数的分母是前一个分数的分子加1fm= fz+1;//后一个分数的分子是前一个分数的分母加1fz=t+1;	}cout<<res*2;return 0;
}
  • 给参与累乘的数字编号,会发现当累乘数字的编号为偶数时,改变分数的分母为下一个奇数,当编号为奇数时,改变分子为下一个偶数。

9.png

​ 代码实现:

#include <bits/stdc++.h>
using namespace std;
int main(int argc, char** argv) {double res=1;int n;cin>>n;double fm=1,fz=2;res*=fz/fm;for(int i=2; i<=n; i++) {if( i%2==0 )fm+=2;else fz+=2;res*=fz/fm;}cout<<res*2;return 0;
}

3.2 公式二

5.png

我们可以把它当成一个累加的问题,但是在累加的时候,又包括有这个累乘的算法,这里我们有两种思考方案。

第一种方式,我们就把相乘当成雷加的一个内嵌的运算式子,就是说用循环嵌套。

#include <bits/stdc++.h>
using namespace std;
int main(int argc, char** argv) {double res=1;int n;cin>>n;for(int i=1;i<=n;i++){double lc=1;double fm=3;for( int j=1;j<=i;j++ ){lc*=j/fm;fm+=2;}res+=lc;}cout<<res*2;return 0;
}

第二种方案,本质上还是一个累加的问题,累加的时候,它要获得一个累乘的效果。一个累乘的值在不停的变化,所以这里我就会声明一个变量。变量用来存储累乘的结果。

#include <bits/stdc++.h>
using namespace std;
int main(int argc, char** argv) {double res=1,lc=1;int n;cin>>n;double fm=3; //分母for(int i=1;i<=n;i++){ //i 分子 lc*=1/fm;res+=lc;fm+=2;}cout<<res*2;return 0;
}

3.3 公式三

7.png

此题也有两种方案,使用二层循环和一层循环。

  • 二层循环。外层循环实现累乘问题,内层循环每次重次计算分母。
#include <bits/stdc++.h>
using namespace std;
int main(int argc, char** argv) {double res=2;int n;cin>>n;for(int i=1;i<=n;i++){double fm=sqrt(2);for( int j=1;j<i;j++){fm=sqrt( 2+fm );}res*=2/fm;}cout<<res;return 0;
}
  • 一层循环。下一次的分母为2减去上一次分母,然后开平方根。
#include <bits/stdc++.h>
using namespace std;
int main(int argc, char** argv) {double res=2;int n;cin>>n;double fm=sqrt(2);for(int i=0;i<n;i++){res*=2/fm;fm=sqrt( 2+fm );}cout<<res;	return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/800586.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SV学习笔记(八)

文章目录 SV入门练习基本数据类型字符串类型数组类型接口的定义与例化类的封装类的继承package的使用随机约束线程的同步线程的控制虚方法方法&#xff08;任务与函数&#xff09;SV用于设计 参考资料 SV入门练习 基本数据类型 有符号无符号、四状态双状态、枚举类型、结构体…

STM32 F401/411外设内部互联矩阵摘要

STM32 F401/411外设内部互联矩阵摘要 &#x1f4cd;参考文档AN4646&#xff1a;https://www.stmcu.com.cn/Designresource/detail/localization_document/709908(中译) -&#x1f4cc; 相关工程案例《HAL STM32主从定时器联级使用》、《STM32G4 TIM1触发ADC转换》 &#x1f4d…

24考研-东南大学916经验贴

文章目录 一、个人情况二、初试备考经验1.政治 67&#xff0c;客观382.英语 60&#xff0c;客观大概40左右3.数学 136&#xff0c;客观应该满分4.专业课 数据结构计网 114小分不清楚 三、复试备考经验笔试&#xff1a;C面试复试流程 附一下成绩单&#xff1a; 一、个人情况 本…

如何给自己的网站添加 https

文章目录 一、简介二、申请 ssl 证书三、下载 ssl 证书四、配置 nginx五、开放 443 端口六、常见问题解决(一)、配置后&#xff0c;访问 https 无法连接成功(二) 证书配置成功&#xff0c;但是访问 https 还是报不安全 总结参考资料 一、简介 相信大家都知道 https 是更加安全…

【利器篇】前端40+精选VSCode插件,总有几个你未拥有!

前言 姊妹篇&#xff1a; 【利器篇】35精选chrome插件&#xff0c;含15前端插件&#xff0c;总有一款值得你停留 关于关于 【前端工具系列】&#xff1a; 有句话&#xff0c;事半功倍&#xff0c;其必然是借助了某些思想和工具。 VSCode是我们前端开发的武器&#xff0c;本文…

Python学习从0开始——专栏汇总

Python学习从0开始——000参考 一、推荐二、基础三、项目一 一、推荐 Hello World in Python - 这个项目列出了用Python实现的各种"Hello World"程序。 Python Tricks - 这个项目包含了Python中的高级技巧和技术。 Think Python - 这是一本教授Python的在线书籍&…

嵌入式Linux系统调用执行基本流程

内核态与用户态 什么是系统调用 系统调用是怎么实现的 库函数write 库函数扩展汇编宏 int 0x80中断 调用对应的中断处理函数 检索系统调用函数表 最终执行sys_write 内核态与用户态数据交互 内核态与用户态 早期工程师们在操作系统上编写程序的时候,自己写个程序可以访问别人…

面试算法-150-缺失的第一个正数

题目 给你一个未排序的整数数组 nums &#xff0c;请你找出其中没有出现的最小的正整数。 请你实现时间复杂度为 O(n) 并且只使用常数级别额外空间的解决方案。 示例 1&#xff1a; 输入&#xff1a;nums [1,2,0] 输出&#xff1a;3 解释&#xff1a;范围 [1,2] 中的数字都…

90天玩转Python—07—基础知识篇:Python中运算符详解

90天玩转Python系列文章目录 90天玩转Python—01—基础知识篇:C站最全Python标准库总结 90天玩转Python--02--基础知识篇:初识Python与PyCharm 90天玩转Python—03—基础知识篇:Python和PyCharm(语言特点、学习方法、工具安装) 90天玩转Python—04—基础知识篇:Pytho…

创建型模式--2.简单工厂模式【人造恶魔果实工厂1】

1. 工厂模式的特点 在海贼王中&#xff0c;作为原王下七武海之一的多弗朗明哥&#xff0c;可以说是新世界最大的流氓头子&#xff0c;拥有无上的权利和无尽的财富。他既是德雷斯罗萨国王又是地下世界的中介&#xff0c;控制着世界各地的诸多产业&#xff0c;人造恶魔果实工厂就…

windows10系统下TP-LINK万兆网卡属性配置高级说明

文章目录 打开配置属性说明ARP Offload&#xff1a;ARP地址解析协议卸载Downshift retries:降档重试次数Energy-Efficient Ethernet:高能效以太网Flow Control:流量控制Interrupt Moderation:中断调整Interrupt Moderation Rate:中断调节率IPv4 Checksum Offload:IPv4校验和卸载…

2024/4/2—力扣—连续数列

代码实现&#xff1a; 思路&#xff1a;最大子数组和 解法一&#xff1a;动态规划 #define max(a, b) ((a) > (b) ? (a) : (b))int maxSubArray(int* nums, int numsSize) {if (numsSize 0) { // 特殊情况return 0;}int dp[numsSize];dp[0] nums[0];int result dp[0];fo…

three.js零基础入门超全超细的教程整理(一)

事情是这样的&#xff1a; 有一天 我干完活 看技术文章 发现了three.js 诶&#xff01;这玩应挺有意思 盘盘 于是第一天找教程 上官网 初上手 第二天 找案例 渲模型 试VR 第三天 捋文档 然后来活了 没时间捋了 下面是集百家精华教程的整理总结 涉及到教程方面有加源作者和地址…

企业3D数字化网络展馆成为企业文化传承与发扬的圣地

在河北这片古老而富饶的土地上&#xff0c;文明的火种薪火相传&#xff0c;燕赵之风历久弥新。河北企业也多年持续稳居我国第五的宝座&#xff0c;企业文化展馆不仅是企业形象的展示窗口&#xff0c;更是企业文化传承与发扬的圣地。 与短暂的行业展会不同&#xff0c;企业展馆是…

JWT身份验证是什么

JWT(JSON Web Token)是一种用于安全传输信息的开放标准(RFC 7519),它可以作为 JSON 对象在各方之间安全地传输信息。JWT通常用于身份验证和声明传递,并且经常用于在客户端和服务器之间进行身份验证和授权。 JWT 的结构 一个 JWT 由三部分组成,每部分之间使用点号 . 分…

用户登录时md5加密源码解析

首先&#xff0c;在登录的时候&#xff0c;将页面提交的密码password加密处理&#xff0c;即password DigestUtils.md5DigestAsHex(password.getBytes()); 接着按ctrl鼠标左键&#xff0c;进入md5DigestAsHex函数中进行查看&#xff1a; 可以发现&#xff0c;md5DigestAsHex函…

xen虚拟机不支持hugepage

今天在xen虚拟机的/etc/sysctl.conf cat /etc/sysctl.conf | grep -i huge vm.nr_hugepages189440 vm.nr_overcommit_hugepages 7500 然后运行sysctl -p使之生效的时候碰到了如下错误 sysctl: setting key “vm.nr_hugepages”: Operation not supported vm.nr_hugepages 18…

顺序表实战——基于顺序表的通讯录

前言&#xff1a;本篇文章主要是利用顺序表作为底层&#xff0c; 实现一个通讯录。偏向于应用&#xff0c; 对于已经学习过c的友友们可能没有难度了已经。没有学习过c的友友&#xff0c; 如果顺序表不会写&#xff0c; 或者说没有自己实现过&#xff0c; 请移步学习顺序表相关内…

ElasticSearch基础及面经

ElasticSearch基础及面经 Elaticsearch&#xff0c;简称为es&#xff0c; es是一个开源的高扩展的分布式全文检索引擎&#xff0c;它可以近乎实时的存储、检索数据&#xff1b;本身扩展性很好&#xff0c;可以扩展到上百台服务器&#xff0c;处理PB级别的数据。es也使用Java开…

【CVE复现计划】CVE-2024-0195

CVE-2024-0195 简介&#xff1a; SpiderFlow是新一代开源爬虫平台&#xff0c;以图形化方式定义爬虫流程&#xff0c;不写代码即可完成爬虫。基于springbootlayui开发的前后端不分离,也可以进行二次开发。该系统/function/save接口存在RCE漏洞&#xff0c;攻击者可以构造恶意命…