程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 編程綜合問答 >> const-用蒙特卡洛方法求解圓周率

const-用蒙特卡洛方法求解圓周率

編輯:編程綜合問答
用蒙特卡洛方法求解圓周率

//蒙特卡洛法求圓周率
#include
#include
#include
#include

using namespace std;

double FindPi(const long n)
{
srand(time(NULL));
long sum = 0;
double x = 0.0, y = 0.0;
for (long i = 0; i < n; i++)
{
x = (double)(rand())/(double)RAND_MAX;
y = (double)(rand())/(double)RAND_MAX;
if (x*x + y*y <= 1)
{
sum++;
}
if (i % 10000 == 0)
{
system("clear");
cout<<"運行了"<<i<<"次運算,完成了總運算的"<<(double)i/(double)n*100.0<<"%"<<endl;
}
}
return 4.0*((double)sum/(double)n);
}

int main()
{
long n = 0;
cout<<"輸入模擬次數:";
cin>>n;
if (n <= 0)
{
cout<<"輸入錯誤"<<endl;
exit(1);
}
double pi = FindPi(n);
cout.precision(50);
cout<<"模擬"<<n<<"次,pi = "<<pi<<endl;
return 0;
}

這個代碼為什麼算出來的總是在3左右,而不是3.14?

最佳回答:


選取的樣本是不是太小了?改大點看看。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved