当前位置:首页 » 编程语言 » c语言计算的圆周率
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

c语言计算的圆周率

发布时间: 2023-05-23 19:08:14

① 求用三种方法计算圆周率(C语言)

给你个C程序吧:
#include <stdio.h>

long a=10000,b,c=2800,d,e,f[2801],g;
void main()
{
for(;b-c;)
f[b++]=a/5;
for(;d=0,g=c*2;c-=14,printf("%04d",e+d/a),e=d%a)
for(b=c;d+=f[b]*a,f[b]=d%--g,d/=g--,--b;d*=b);
}
PI=3.510597317328160963185...

② 能用C语言或C#语言算圆周率吗

是的,C 语言和 C# 语言都可以用来计算圆周率。

多边形法是一种常用的求圆周率的方法,其基本思路是将一个正多边形内接于单位圆上,通过不断增加多边形的边数,槐斗脊逐渐逼近圆的周长和面积。具体来说,我们可以使用如下的 C 语言或 C# 语言代码实现:

```c
#include <stdio.h>
#include <math.h>

int main() {
int n = 6; // 初始为六边形

double side = 1.0; // 正多边销老形的边长
double radius = 1.0; // 单位圆的半径
double pi = 0.0; // 圆周率的估计值

while (n <= 1048576) { // 增加多边形的边数直到达到 2^20
side = 2 * radius * sin(M_PI / n);
radius = sqrt(pow(radius, 2) - pow(side / 2, 2));
pi = n * side / 2; // 计算圆周率的估计值
printf("%d 边形:%.15f\n", n, pi);
n *= 2;
}

return 0;
}
```

在上述代码中,我们首先定义了三个变量 `side`、`radius` 和 `pi`,分别铅渗表示正多边形的边长、单位圆的半径和圆周率的估计值。初始时,我们将正多边形初始化为一个六边形,即 `n=6`。然后,我们在一个循环内不断增加正多边形的边数,直到边数达到 $2^{20}$。在每次循环中,我们使用正多边形的边长公式和勾股定理计算出新的正多边形的边长和半径,并根据正多边形的计算结果计算出圆周率的估计值 `pi`,并输出结果到控制台中。

需要注意的是,在实际应用中,还需要考虑数值溢出、精度误差等问题,以确保计算结果的正确性。

③ C语言计算圆周率

#include<stdio.h>
doublefact(intn)
{
doubleres=1.0;
for(inti拆氏改=1;i<=n;i++)
核斗res*=i;
returnres;
}
doublemulti(intn)
{
doubleres=1.0;
for(inti=1;i<=n;i+=2)
res*=旅判i;
returnres;
}
intmain()
{
doublesum=1.0,item=1.0,eps=1e-6;
for(inti=1;item>=eps;i++)
{
item=fact(i)/multi(2*i+1);
sum=sum+item;
}
printf("PI=%0.5lf ",sum*2);
return0;
}
//这样可以得到3.14159

④ C语言:圆周率的计算

在for循环后加一句: sum -= f;
你多加了最后那个小于epsioon的值。

⑤ 用C语言编一个计算圆周率的程序,用户输入指定位数,并计算到指定位数(精度不够可以用整数)

#include "stdio.h"

#include <stdlib.h>

#include <string.h>

int main(int argc,char *argv[]){

int a,b,c,d,e,f[2801],g,i,n;

char pi[801]="",t[5]="";

for(a=10000,b=0,c=2800;b-c;f[b++]=2000);//a/5

for(i=e=0;d=0,g=c*2;c-=14,e=d%a){

for(b=c;d+=f[b]*a,f[b]=d%--g,d/=g--,--b;d*=b);

n=e+d/a,t[0]=t[1]=t[2]=t[3]='';

n<10 ? t[0]=t[1]=t[2]='0',i=3 : n<100 ? t[0]=t[1]='0',i=2 : n<1000 ? t[0]='0',i=1 : i=0;

itoa(n,t+i,10);

strcat(pi,t);

}

printf("Please enter the length n(int 0<n<800)... n=");

if(scanf("%d",&n)!=1 || n<1 || n>800){

printf("Input error, exit... ");

return 0;

}

for(i=0;i<n;printf("%c",pi[i++]));

printf(" ");

return 0;

}

代码格式和运行样例图片:

⑥ C语言计算圆周率

计算溢出了。你的 fact 和 multi 都使用整数保存计算结果,参数稍大带谨纤一点就超出整数表示范围了,于是溢蠢仿出变成负数。
你把这两个函数改成 double 类晌指型,内部变量 res 也声明成 double,就能算出正确结果了。

⑦ C语言的求π的值

#include <stdio.h>

#include <math.h>


int main(){

double pi=0,result;

int i=1;

int s=-1;

do{

s*=-1;

result=1.0/i*s;

i+=2;

pi+=result;

}while(fabs(result)>0.000001);

printf("pi=%10.4lf ",pi*4);

return 0;

}

⑧ C语言编程计算圆周率π到小数点后五位

1.
#include "stdio.h"

int main()
{
float pi=0.0f;
int i=0;
do
{
pi+=1.0/迟棚凳(i*2+1)*(i%2?1:-1);
i++;
}while(1.0/i>和局0.00001);
pi*=4;
printf("pi=%0.5f",pi);
}

2.
#include "stdio.h"

int main()
{
double pi=1.0;
int i=1;
do
{
pi*=2.0*i/码旅(2*i-1)*2.0*i/(2*i+1);
i++;
}while(i<100000);
pi*=2;
printf("pi=%0.5f",pi);
}

⑨ C语言 求圆周率~~

用的是如图的公式,下面是arctg展开的级数。

这个输出没有写好,一派笑陆组是10位,如果前面是“0”就会少了,要完善一下。

N是定义算多少组的,N=1000时N*10就是10000组,要算到100万位这种算法要好长时间,但是这是最简单的算法之一。

下面分成三个部分,第一是定义数组和

#defineN1000

#include"math.h"

#include"string.h"

main()

{

autodoublea1,b1,b2,c1,d,i=1.0,q=-1.0;

autodoublen,g,r=10000000000.0;

staticdoublea[N+1],b[N+1],c[N+1];

autochar*str3,str1[15],strs1[11*N],*p_strs1;

autolongp,j,k=1,m=1;

do{

printf("inputp=");

scanf("%ld",&p);

}while(p<=0&&p>100);

p=p+1;

b[1]=r*20.0,c[1]=239*r;

do

{q=-q,a1=0,b1=0,c1=0;

for(j=m;j<=p;j++){c1=c[j]+c1*r,c[j]=floor(c1/57121),c1=c1-c[j]*57121;}

if(c[m]<1e-5)m++;

for(j=k;j<=p;j++){

a1=b[j]+a1*r,b[j]=floor(a1/25.0),a1=a1-b[j]*25.0;

升改d=b1*r+b[j]-c[j],b1=floor(d/i),a[j]=4*q*b1+a[j];

b1=d-b1*i;

}

if(b[k]<=1e-5){

k++;

printf("k=%ld尘顷",k);}

i=i+2;

}while(m<=p);

do

{q=-q,a1=0,b1=0;

for(j=k;j<=p;j++){

a1=b[j]+a1*r,b2=floor(a1/25),b[j]=b2;

a1=a1-b2*25,d=b2+b1*r;

b1=floor(d/i),a[j]=a[j]+4*q*b1;

b1=d-b1*i;

}

if(b[k]<=1e-5){k++;printf("k=%ld",k);}

i=i+2;

}while(k<=p);

printf(" ");

for(j=p;j>=1;j--){g=a[j]+n,n=floor(g/r),a[j]=g-r*n;}

for(j=1;j<p;j++)printf("%10.0f",a[j]);

str3=strs1;

}

⑩ C语言计算圆周率

#include<stdio.h>
#include<math.h>
intmain(){
doublep=0,q=0;
inti;
for(i=1;;i++){
p+=6*1.0/(i*i);
q+=4*1.0*pow(-1,i+1)/(2*i-1);//q后面少一个+
if(fabs(sqrt(p)-q)<1e-6)
break;
}
printf("PIis%lf,项数为%d",q,i);
return0;
}