查看單個文章
舊 2008-05-26, 02:26 PM   #3 (permalink)
rank
註冊會員
榮譽勳章
UID - 293162
在線等級: 級別:2 | 在線時長:18小時 | 升級還需:3小時級別:2 | 在線時長:18小時 | 升級還需:3小時
註冊日期: 2008-02-12
文章: 327
精華: 0
現金: 16 金幣
資產: 16941 金幣
預設

小弟我來指教啦~
其實這修改還不是很完整

語法:
#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
請按任意鍵繼續 . . .
rank 目前離線  
送花文章: 362, 收花文章: 221 篇, 收花: 411 次
回覆時引用此帖