1. c语言求e的值
printf("%lf\n",e);
改成
printf("%.100lf\n",e);
因为double精度只能显示10多位,后面是0.
一定要精度换数组保存.
2. C语言 编写程序求e的值 e=1+1/1!+1/2!+1/3!+......
#include <stdio.h>
int main() {
long int i, k;
double n=1.0l;/*n!
double s = 1.0l;
for (i = 1; i < 50; i++) {
n=n*i;
s += 1.0 / n;
}
printf("e = %lf ", s);
getchar();
return 0;
}
或:
public class Test{
public static void main(String args[]){
double sum=1,n=1;
double e=1;
for(n=1;n<=10;n++){
sum=sum*n;
e+=1/sum;}
System.out.println("e="+e);
}
}
得到的值为:2.7182818011463845...
随着n值越专大得到的e值越精属确。
(2)c语言求e的最简单方法扩展阅读:
C语言包含的各种控制语句仅有9种,关键字也只有32 个,程序的编写要求不严格且以小写字母为主,对许多不必要的部分进行了精简。实际上,语句构成与硬件有关联的较少,且C语言本身不提供与硬件相关的输入输出、文件管理等功能,如需此类功能,需要通过配合编译系统所支持的各类库进行编程,故c语言拥有非常简洁的编译系统。
3. C语言编程计算e
楼主你好
具体代码如下:
#include<stdio.h>
int main()
{
double e=1,index;
int i=1,j=1;
do{
i*=j;
index=1.0/i;
e+=index;
j++;
}while(index>=1E-6);
printf("e=%.5f\n",e);
return 0;
}
希望能帮助你哈
4. c语言编程求自然数e
#include "stdio.h"
void main()
{
int k,j;
long m;
double e=0;
for(k=0;;k++)
{
// k!
for(j=1,m=1;j<=k;j++)
{
m*=j;
}
e+=1.0/m;
if(1.0/m < 0.000001)
break;
}
printf("e=%lf",e);
printf("\npress any key to exit:\n");
getch();
}
运行结果:
e=2.718282
press any key to exit:
5. C语言编一个计算e的值的程序
//double??
for(i=1.000000;n>=EPSILON;++i)
{
z=z*i;//阶乘
n=m/z;//求反
t=t+n;//求和
}
你是想表达这个意思吧
doubles,e,n,z,m,t,i;//1.不需要全部使用double的
//double是处理小数位数多的时候进行使用的
//double和float都是一个相似值
t=0.000000;
m=1.000000;
s=1.000000;
z=1.000000;
for(i=1.000000;n>=EPSILON;++i)//n的初始化呢?n什么时候才能够>=EPSILON
//所以你这里应该使用dowhile的结构,而不是for
{
z=z*i;//这里的问题,就是我前面标示的,
//longlong会更精确一点,而1.0000001*1.0000002的结果会对下面有影响的
n=m/z;//m始终没有改变过,没有必要使用一个变量:)
//n=double(1)/z;
t=t+n;//t+=n;个人习惯
}
e=t+1.000000;
printf("e=%.6lf",e);
return0;
6. c语言求e 两种方法
// 我先提供一种/* e = 1 + 1/1! + 1/2! + 1/3!+........1/n!+.... ... */
#include <math.h>
#include <stdio.h>void main() {
double e = 1.0,delta;
int factorial = 1,i = 1;
do {
delta = 1.0/factorial;
e = e + delta;
i++;
factorial = factorial*i;
} while(fabs(delta) > 1.0e-6);
printf("e = %lf\n",e);
}
7. c语言中怎求数学中的e是多少啊
我给你介绍一个公式吧:(泰勒工式展开式)
e=1+ 1 + 1/2! +1/3! +1/4! +1/5! + ...+ 1/n!
其中,n!表示n的阶乘:n!=n*(n-1)*(n-2)*...*3*2*1;可以专门设计一个子函数求 n! ;(n越大,精确度越高)
下面是代码:
//网页上直接写的,在VC++6.0运行时如果编译出错,那就改一下分
//号和逗号
#include<stdio.h>
#define N 20
int jiecheng(int n)
{
int i=n;
int result=1;
while(i)//
{
result*=i;
i--;
}
return result;
}
void main()
{
int i;
double e=2;
for(i=2;i<N;i++)
{
e+=1/(jiecheng(i)*1.0)
}
printf("e=%lf\n",e);
}
8. 用c语言怎样求自然常数e
代码如下
:
运行过了
输出e=2.718282
不知是否满意
望采纳
#include
void
main(){
long
fun(int
n);
int
i;
double
e=0;
double
eps=1e-6;//eps表示精度
此处指10的-6次方
for(i=0;1.0/fun(i)>eps;i++)
{
e+=1.0/fun(i);
}
printf("e=%lf\n",e);
}
long
fun(int
n)//求n!的函数
{
if(n==0)
return
1;
else
return
n*fun(n-1);
}
9. C语言,据以下公式求e的值。要求用两种方法计算:
#include <stdio.h>
int main()
{
int i;
double sum,t;
for(t=i=1,sum=1;i<50;++i)
{
t*=i;
sum+=1.0/t;
}
printf("%lf ",sum);
return 0;
}
10. 求c语言程序,求e,用递归函数
用c语言程序,求e,用递归函数,最易于实现的计算方法应该是使用e的极限近似计算,以下以n=1000近似计算之:
n=10000时的近似结果