问题就是出在数据类型上的选用上,precision=0.0000001时已经超过了float的数据范围,所以导致数据截断后precision=0.000000,从而程序在计算积分时可能陷入死循环,应该采用double型数据类型。其实不推荐楼主用如此多的define语句,程序的可读性和风格应该重于编程员的劳动度。。。
还有楼主对自然对数e的define也已经超过了计算机的可识别范围。。您那样精确的定义e并不会在结果上获得更加精确地结果,其实反倒会起到相反的作用,要知道与其用一个这样可能导致内存出错以及必定会导致数据截断的变量来实现精度的提高远远不如采用一个更精确的积分算法,而且c语言提供了自然数e为底的指数函数~而且貌似您的积分算法是不准确的,梯形积分的定义并非如此,其再两端的函数值应该只取1/2.希望您多加细心~
如果不介意的话,就是你的precision应该改为step~这样会能更加准备的表达了这个变量的作用,在你的程序中precision变量其实是积分步长~在数值计算方法中积分精度的控制往往不是通过细化步长来表达,而是通过后一个积分值-前一个积分值
只是给出相关代码段:
float f=0.0;
float x=1.0;
while(x<10)
{
f+=x*x*sin(x)+x*cos(x);
x+=0.05;
}
f*=0.05;
printf("%f\n",f);
定积分采用定义积分,梯形面积和
s=0;
for(x=1,x<=10,)
{f=x^2*sin(x)+x*cos(x);
s=s+f*0.05;
i=i+0.05;}
#include
#include
void main()
{
float f=0.0;
float x=1.0;
while(x<10.0)
{
f+=sqrt(x)*sin(x)+x*cos(x);
x+=0.05;
}
printf("%f\n",f);
}