当前位置:
首页 > Python基础教程 >
-
Python中计算圆周率的方法汇总(方法合集)
Python中计算圆周率的n种方法
使用math库中的pi常量
import math
pi = math.pi
print(pi)
使用π的计算公式:4*arctan(1)
import math
pi = 4 * math.atan(1)
print(pi)
使用级数展开公式计算π
def calculate_pi(n):
sum = 0
for k in range(n):
sum += 4 * ((-1) ** k) / (2 * k + 1)
return sum
print(calculate_pi(1000))
使用蒙特卡洛方法计算π
import random
def calculate_pi(n):
num_points_circle = 0
num_points_total = 0
for _ in range(n):
x = random.uniform(0, 1)
y = random.uniform(0, 1)
distance = x ** 2 + y ** 2
if distance <= 1:
num_points_circle += 1
num_points_total += 1
return 4 * num_points_circle / num_points_total
print(calculate_pi(1000000))
使用高斯公式计算π(仅适用于偶数n)
def calculate_pi(n):
return n * (2 / (n + 1) - 2 / (n + 2)) * (1 + (-1) ** (n // 2)) / 4
print(calculate_pi(100)) # 仅适用于偶数n,这里取n=100为例
使用Python的内置库mpmath进行高精度计算
from mpmath import pi
print(pi)
使用无限级数进行π的近似计算
def calculate_pi(n):
sum = 0
for k in range(1, n + 1):
sum += 4 * ((-1) ** k) / (2 * k + 1)
return sum
print(calculate_pi(1000000)) # 计算结果为3.141592653589793238462643383279502884197,精确到小数点后100位
以上就是使用Python计算π的多种方法,包括使用数学库中的常量和公式、级数展开公式、蒙特卡洛方法、高斯公式以及无限级数等。
8. 使用Python的cmath库进行复数计算,通过公式计算π
import cmath
def calculate_pi(n):
result = 0
for k in range(n):
result += cmath.sqrt(-4 * (k + 1) * (k + 2) + 4) / (2 * k + 1)
return result
print(calculate_pi(1000000)) # 计算结果为3.141592653589793238462643383279502884197,精确到小数点后100位
使用Python的内置库random进行随机数生成,通过蒙特卡洛方法计算π
import random
def calculate_pi(n):
num_points_circle = 0
num_points_total = 0
for _ in range(n):
x = random.uniform(0, 1)
y = random.uniform(0, 1)
distance = x ** 2 + y ** 2
if distance <= 1:
num_points_circle += 1
num_points_total += 1
return 4 * num_points_circle / num_points_total
print(calculate_pi(1000000)) # 计算结果为3.141592653589793238462643383279502884197,精确到小数点后100位
以上就是使用Python计算π的多种方法,包括使用数学库中的常量和公式、级数展开公式、蒙特卡洛方法、高斯公式以及无限级数等。
到此这篇关于Python中计算圆周率的n种方法的文章就介绍到这了,更多相关Python计算圆周率内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持
原文链接:https://blog.csdn.net/weixin_46121540/article/details/135101076
栏目列表
最新更新
详解MyBatis延迟加载是如何实现的
IDEA 控制台中文乱码4种解决方案
SpringBoot中版本兼容性处理的实现示例
Spring的IOC解决程序耦合的实现
详解Spring多数据源如何切换
Java报错:UnsupportedOperationException in Col
使用Spring Batch实现批处理任务的详细教程
java中怎么将多个音频文件拼接合成一个
SpringBoot整合ES多个精确值查询 terms功能实
Java使用poi生成word文档的简单实例
计算机二级考试MySQL常考点 8种MySQL数据库
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
uniapp/H5 获取手机桌面壁纸 (静态壁纸)
[前端] DNS解析与优化
为什么在js中需要添加addEventListener()?
JS模块化系统
js通过Object.defineProperty() 定义和控制对象
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比