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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

7-15 计算圆周率 (15 分)

發布時間:2023/12/1 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 7-15 计算圆周率 (15 分) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

根據下面關系式,求圓周率的值,直到最后一項的值小于給定閾值。

輸入格式:
輸入在一行中給出小于1的閾值。

輸出格式:
在一行中輸出滿足閾值條件的近似圓周率,輸出到小數點后6位。

輸入樣例:

0.01

結尾無空行
輸出樣例:

3.132157

第一次寫的代碼可以運行,但是無法通過,提示直接計算階乘會超出長整型

#include <stdio.h> int funup(int n); int fundown(int n); int main () {int i = 0;double prn;double result = 0,iteam = 1;scanf("%lf",&prn);while(iteam>prn){iteam = 1.0*funup(i)/fundown(i);result += iteam;i++;}printf("%f",2*result);return 0; } int funup(int n) {int result = 1;if(n == 0){result = 1;}else{for(int i = 1;i<=n;i++){result *= i;}}return result; } int fundown(int n) {int result = 1;for(int i =0;i<=n;i++){result *= (2*i+1);}return result; }

后來參考了別人的代碼寫的就通過了

#include <stdio.h>int main() {double up = 1,down = 1,item = 1,t = 0,sum = 1;int i = 1;scanf("%lf",&t);do{up *= i;down *= (2*i+1);item = 1.0*up/down;sum += item;i++;}while(item>t);printf("%f",sum*2);return 0; }

有點不明白,為什么第一次單獨計算分子的階乘就說超出范圍了?第二次“up *= i;”不也是算出來階乘嗎?

還有用遞歸的方法,更巧妙了

#include<bits/stdc++.h> using namespace std; double getnum(int x){if(x == 1) return 1;else return getnum(x - 1) * x; } double getnnum(int x){if(x == 1) return 1; else return getnnum(x - 1) * (2 * x - 1); } int main(){double pi = 1, n = 1, m, up = 1, down = 1;cin >> m;while(up / down >= m){up = getnum(n);down = getnnum(n + 1);pi += up / down;n++;}printf("%.6lf", (double)pi * 2);return 0; }

代碼內容參考了這兩篇文章
https://blog.csdn.net/weixin_45031646/article/details/90147530
https://blog.csdn.net/qiguanjiezl/article/details/102737041

總結

以上是生活随笔為你收集整理的7-15 计算圆周率 (15 分)的全部內容,希望文章能夠幫你解決所遇到的問題。

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