精确到最后一项的绝对值小于ee:
来源:学生作业帮助网 编辑:作业帮 时间:2024/09/22 09:56:50
#include <stdio.h> //头文件置顶#include <math.h>double fact(int n){\
这样写应该可以的:#include#includemain(){\x05inti=1,x=1;\x05floatsum=1;\x05while(abs(1.0/x)>=1e-5)\x05{\x05\x
#include#include//这个函数需要返回double类型,不然结果很快就溢出了doublef(intn){\x05inti;\x05doublem=1.0;\x05for(i=1;i=e)
C语言吗?发给你#includemain(){\x05inti=1,flag=1;\x05floatsum=0,next=1;\x05while(next>=1e-3)\x05{sum=sum+(ne
g再问:shenmeyisi什么意思?再答:youaresobed.itisfgasdwswimmingdoingin.再问:汗英语也说得这么糊涂你还是用拼音说吧还有这程序是我自己写的但我实在查不出哪
while(表达式),这里的表达式是满足循环的条件,不是结束循环的条件,它们刚好相反如果x值为1,乘上-1,x的值就变为-1,再乘-1就变成+1了.所以对于x来说相当于是交替出现正负号再问:但是题目不
将while(fabs(sum)>=e){item=flag*pow(x,i)*1.0/fact(n);sum=sum+item;flag=-flag;i=i+2;n=n+2;}改为:do{item=
x*=(-1.0)*(2*i-3)/(2*i-1);当i=3时,你的分母为3了,不是1;x*=(-1.0)*(2*i-3)/(2*i-1);这句,当i=1时,x=1;i=2时,x=-1/3;i=3时,
#include<stdio.h>#include<math.h>int main(void){ double x, e,cosx;&n
因为你的item一开始没有初始化编译器就给你一个特别小的负数所以你运行就直接跳出while循环了再问:初始了item=1后,还是不行...是不是程序上问题...再答:item=flag*pow(x,2
这个是用N阶麦克劳林公式求函数值,我马上帮你写.麻烦采纳,谢谢!
认真看了你的代码,没有问题,只是我用的VS2010sum=sum+pow(-1,n+1)*pow(x,2*(n+1))*1.0/(fact(2*(n+1))); 这句里需要改一下
把y=y+item;改成y=y+(int)item;把printf("sum=%f\n",sum);改成printf("sum=%f\n",sum);就应该可以了.再问:改好之后变成这样了,可是正确答
#include#includemain(){doublee,x;doublecosx(doublex);scanf("%lf%lf",&e,&x);printf("%f\n",cosx(x));re
指出几个问题吧..(1)doublefuncos(doublee,doublex);函数申明应该放在main函数外面;(2)doublefuncos(doublee,doublex)函数里面的sum变
#includedoublechenfang(inti)//计算符号是1还是-1{intx=i%2;if(x==0)return1;return-1;}doublecomputePai()/
a-π的绝对值+根号2-a的绝对值=π-a+a-根号2=π-根号2=3.14-1.41=1.73
呵呵,看看是这意思?OptionExplicitConstpi=3.14159265358979PrivateSubCommand1_Click()Dimx,nAsInteger,kAsInteger
如果你说的e不是2.71828的话,那么程序应该是如下:#include#defineER0.0001//允许的误差intmain(){floate=0.0,et=0.0;intn=1;et=1.0;