#include <stdio.h>
#include <math.h>
int main()
{
float y1,y2,y3,y4,y5;
float f1(float);
float f2(float);
float f3(float);
float f4(float);
float f5(float);
float integral (float a,float b,float(*fun)(float));
float a,b;
printf("please enter a and b:");
scanf("%f,%f",&a,&b);
y1=integral(a,b,f1);
printf("result1 =%6.2f\n",y1);
y2=integral(a,b,f2);
printf("result2 =%6.2f\n",y2);
y3=integral(a,b,f3);
printf("result3 =%6.2f\n",y3);
y4=integral(a,b,f4);
printf("result4 = %6.2f\n",y4);
y5=integral(a,b,f5);
printf("result5 = %6.2f\n",y5);
return 0;
}
float f1(float x)
{
float z;
z=1+x;
return (z);
}
float f2(float x)
{
float z;
z=2*x+3;
return (z);
}
float f3(float x)
{
float z;
z=exp(x)+1;
return (z);
}
float f4(float x)
{
float z;
z=1+2*x+pow(x,2);
return (z);
}
float f5(float x)
{
float z;
z=pow(x,3);
return (z);
}
float integral(float a,float b,float(*fun)(float))
{
float s, h, y;
int n, i;
s = ( (*fun)(a) + (*fun)(b) ) /2.0;
n = 100;
h = (b-a)/n;
for(i=1; i<n; i++)
s = s + (*fun)(a+i*h);
y = s * h;
return y;
}
错误点:1.定义的float型却在scanf时以%d输入
2. y1=integral(a,b,f1);
printf("result1 =%6.2f\n",y1); 未改之前顺序颠倒