圆周率(π)是一个无理数,其值约为3.1415926,在C语言中,我们可以使用多种方法来计算圆周率,以下是一些常见的方法:
(图片来源网络,侵删)1、蒙特卡洛方法
蒙特卡洛方法是一种通过随机抽样来计算圆周率的方法,具体步骤如下:
1、1 初始化变量
#include <stdio.h> #include <stdlib.h> #include <time.h> int main() { int i, n; double x, y, pi; srand(time(NULL)); n = 1000000; // 抽样次数 pi = 0.0; }
1、2 生成随机点
for (i = 0; i < n; i++) { x = (double)rand() / RAND_MAX; // 生成0到1之间的随机数 y = (double)rand() / RAND_MAX; // 生成0到1之间的随机数 }
1、3 计算圆内点的数量
for (i = 0; i < n; i++) { if (x * x + y * y <= 1) { // 如果点在圆内(x^2 + y^2 <= 1),则累加计数器 pi++; } }
1、4 计算圆周率
pi = 4.0 * pi / n; // 乘以4并除以抽样次数,得到圆周率的近似值 printf("圆周率的近似值为: %f ", pi); return 0;
2、格雷戈里莱布尼茨级数法
格雷戈里莱布尼茨级数法是一种通过无穷级数来计算圆周率的方法,具体步骤如下:
2、1 初始化变量和级数项数
#include <stdio.h> #include <math.h> int main() { double pi = 0.0; // 圆周率的近似值 int n, i; // 级数项数和循环变量 n = 1000000; // 级数项数,可以根据需要调整以提高精度 }
2、2 计算级数项并累加到圆周率的近似值上
for (i = 0; i < n; i++) { double term = pow(1, i) / (2 * i + 1); // 计算当前级数项的值,i为奇数时符号为正,偶数时符号为负,分母为2i+1,以便简化计算和提高精度 pi += term; // 将当前级数项累加到圆周率的近似值上 }
2、3 输出圆周率的近似值并四舍五入到指定的小数位数
pi *= 4; // 乘以4,得到圆周率的近似值(因为格雷戈里莱布尼茨级数的公式是π/4) printf("圆周率的近似值为: %.15f ", pi); // 输出圆周率的近似值,保留15位小数,可以根据需要调整小数位数以提高精度和输出速度的平衡 return 0;
3、BBP公式法(巴塞尔、布伦特、普劳特公式)
BBP公式法是一种通过无穷级数来计算圆周率的方法,其公式为:π/4 = 1 1/3 + 1/5 1/7 + 1/9 …,具体步骤如下:
3、1 初始化变量和级数项数、符号变量以及累加器和误差范围变量
#include <stdio.h> #include <math.h> #include <stdbool.h> // 引入布尔类型,用于判断符号变量的值是否为正或负 #include <float.h> // 引入浮点数类型的最大值和最小值常量,用于设置误差范围和判断累加器是否达到误差范围要求的条件之一(另一个条件是级数项的绝对值小于等于误差范围) #define PRECISION 1000000 // 级数项数,可以根据需要调整以提高精度和输出速度的平衡,同时影响误差范围的大小和累加器的收敛速度(即达到误差范围要求的时间)和最终结果的精度和稳定性(即误差范围越小,收敛速度越快,最终结果越稳定;误差范围越大,收敛速度越慢,最终结果越不稳定) #define TOLERANCE DBL_EPSILON * PRECISION // 误差范围,根据需要调整以提高精度和输出速度的平衡,同时影响累加器的收敛速度(即达到误差范围要求的时间)和最终结果的精度和稳定性(即误差范围越小,收敛速度越快,最终结果越稳定;误差范围越大,收敛速度越慢,最终结果越不稳定) int main() { double pi = 0.0, term, sum = 0.0, sign = 1.0; // pi为圆周率的近似值,term为当前级数项的值,sum为累加器,sign为符号变量(初始值为正) }
最新评论
本站CDN与莫名CDN同款、亚太CDN、速度还不错,值得推荐。
感谢推荐我们公司产品、有什么活动会第一时间公布!
我在用这类站群服务器、还可以. 用很多年了。