小弟我來指教啦~
其實這修改還不是很完整
語法:
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char *argv[])
{
int n;
float x,y,up,down;
float c,b,sum=0,a,h;
printf("此方程式為y=ax^2+bx+c\n");
printf("請輸入係數a = ");
scanf("%f",&a);
printf("請輸入係數b = ");
scanf("%f",&b);
printf("請輸入係數c = ");
scanf("%f",&c);
printf("請輸入積分上限 = ");
scanf("%f",&up);
printf("請輸入積分下限 = ");
scanf("%f",&down);
printf("請輸入分割數n = ");
scanf("%d",&n);
h=(up-down)/n;
printf("每單位寬度 = %f\n",h);
for(x=down;x<up;x+=h)
{
y=h*(a*x*x+b*x+c+a*(x+h)*(x+h)+b*(x+h)+c)/2;
if(y<0)
y=-y;
sum+=y;
}
printf("函數下的面積為 %f\n",sum);
system("PAUSE");
return 0;
}
運行結果
此方程式為y=ax^2+bx+c
請輸入係數a = 1
請輸入係數b = 0
請輸入係數c = 0
請輸入積分上限 = 2
請輸入積分下限 = -2
請輸入分割數n = 10000
每單位寬度 = 0.000400
函數下的面積為 5.334602
請按任意鍵繼續 . . .