Python中計(jì)算圓周率的方法匯總(方法合集)
Python中計(jì)算圓周率的n種方法
使用math庫(kù)中的pi常量
import math pi = math.pi print(pi)
使用π的計(jì)算公式:4*arctan(1)
import math pi = 4 * math.atan(1) print(pi)
使用級(jí)數(shù)展開公式計(jì)算π
def calculate_pi(n): sum = 0 for k in range(n): sum += 4 * ((-1) ** k) / (2 * k + 1) return sum print(calculate_pi(1000))
使用蒙特卡洛方法計(jì)算π
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))
使用高斯公式計(jì)算π(僅適用于偶數(shù)n)
def calculate_pi(n): return n * (2 / (n + 1) - 2 / (n + 2)) * (1 + (-1) ** (n // 2)) / 4 print(calculate_pi(100)) # 僅適用于偶數(shù)n,這里取n=100為例
使用Python的內(nèi)置庫(kù)mpmath進(jìn)行高精度計(jì)算
from mpmath import pi print(pi)
使用無(wú)限級(jí)數(shù)進(jìn)行π的近似計(jì)算
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)) # 計(jì)算結(jié)果為3.141592653589793238462643383279502884197,精確到小數(shù)點(diǎn)后100位
以上就是使用Python計(jì)算π的多種方法,包括使用數(shù)學(xué)庫(kù)中的常量和公式、級(jí)數(shù)展開公式、蒙特卡洛方法、高斯公式以及無(wú)限級(jí)數(shù)等。
8. 使用Python的cmath庫(kù)進(jìn)行復(fù)數(shù)計(jì)算,通過(guò)公式計(jì)算π
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)) # 計(jì)算結(jié)果為3.141592653589793238462643383279502884197,精確到小數(shù)點(diǎn)后100位
使用Python的內(nèi)置庫(kù)random進(jìn)行隨機(jī)數(shù)生成,通過(guò)蒙特卡洛方法計(jì)算π
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)) # 計(jì)算結(jié)果為3.141592653589793238462643383279502884197,精確到小數(shù)點(diǎn)后100位
以上就是使用Python計(jì)算π的多種方法,包括使用數(shù)學(xué)庫(kù)中的常量和公式、級(jí)數(shù)展開公式、蒙特卡洛方法、高斯公式以及無(wú)限級(jí)數(shù)等。
到此這篇關(guān)于Python中計(jì)算圓周率的n種方法的文章就介紹到這了,更多相關(guān)Python計(jì)算圓周率內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于Python實(shí)現(xiàn)倒計(jì)時(shí)工具
這篇文章主要為大家詳細(xì)介紹了基于Python實(shí)現(xiàn)倒計(jì)時(shí)工具,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08pytorch?collate_fn的基礎(chǔ)與應(yīng)用教程
這篇文章主要給大家介紹了關(guān)于pytorch?collate_fn基礎(chǔ)與應(yīng)用的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-02-02python實(shí)現(xiàn)感知機(jī)線性分類模型示例代碼
這篇文章主要給大家介紹了關(guān)于python實(shí)現(xiàn)感知機(jī)線性分類模型的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用python具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06pygame可視化幸運(yùn)大轉(zhuǎn)盤實(shí)現(xiàn)
這篇文章主要介紹了pygame可視化幸運(yùn)大轉(zhuǎn)盤實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04python數(shù)據(jù)可視化plt庫(kù)實(shí)例詳解
這篇文章主要介紹了python可視化數(shù)據(jù)plt庫(kù)實(shí)例,下面使用pycharm環(huán)境給大家詳細(xì)介紹,文中提到j(luò)upyter和pycharm環(huán)境的差別,需要的朋友可以參考下2021-06-06python下函數(shù)參數(shù)的傳遞(參數(shù)帶星號(hào)的說(shuō)明)
python中函數(shù)參數(shù)的傳遞是通過(guò)賦值來(lái)傳遞的。2010-09-09Python基于numpy靈活定義神經(jīng)網(wǎng)絡(luò)結(jié)構(gòu)的方法
這篇文章主要介紹了Python基于numpy靈活定義神經(jīng)網(wǎng)絡(luò)結(jié)構(gòu)的方法,結(jié)合實(shí)例形式分析了神經(jīng)網(wǎng)絡(luò)結(jié)構(gòu)的原理及Python具體實(shí)現(xiàn)方法,涉及Python使用numpy擴(kuò)展進(jìn)行數(shù)學(xué)運(yùn)算的相關(guān)操作技巧,需要的朋友可以參考下2017-08-08