日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

圆周率计算——蒙特卡罗方法

發布時間:2024/1/1 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 圆周率计算——蒙特卡罗方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

要求:

(1)使用蒙特卡羅方法

(2)打印進度條

(3)計算用時

蒙特卡羅方法(向一個單位圓及其單位正方形拋點,取其四分之一來算,結果再乘上4即可)

話不多說,直接上代碼

import time import random dian=pow(10,6) #拋一百萬個點,別拋太多,會用時過多,當拋到一定數量的點后,其精確值都差不多了 youxiaodian=0 #落在圓內的點 start=time.perf_counter() #計時 for i in range(1,dian+1):a='*'*int((i/dian)*100) #a,b,c都是打印進度條用b='.'*int(((dian-i)/dian)*100)c=int((i/dian)*100)print("\r當前進度:{:^3.0f}% [{}->{}]".format(c, a, b),end="") #打印進度條x,y=random.random(),random.random() #x,y取0-1的隨機數(因為是單位圓)if pow((x*x+y*y),1/2)<1: #r=1,點(x,y)到圓心的距離=x平方+y平方開根號youxiaodian+=1 #小于半徑的話就表示落在1/4圓內,園內點+1 pi=4*(youxiaodian/dian) #剛剛計算的只是1/4圓周率,所以×4 print("\n") print("圓周率pi接近于{}, 計算用時{}秒".format(pi,time.perf_counter()-start).center(100,"="))

運行結果:

當前進度:100% [****************************************************************************************************->]==================================圓周率pi接近于3.13702, 計算用時11.517367秒==================================

注:每次運行的pi值并不是一樣的,因為引用了random函數,結果只能接近于真實的pi值,要想運行的結果每次都一樣,可以采用random.seed(n)獲取隨機種子。

總結

以上是生活随笔為你收集整理的圆周率计算——蒙特卡罗方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。