我的一项任务是创建一个使用辛普森1/3规则找到总和的c程序。我遇到了我无法修复的问题。有更多经验的人能否指出我的方向正确?辛普森规则集成
理论上我的代码集成了y = ax^2 + bx + c,其中用户选择a,b,c的值,然后用户选择上下限[d,e]。然后用户选择将该区域分割成更多矩形的n值(我们在课堂中使用的值为100,因此该区域被分割成100个矩形)。之后它贯穿辛普森的规则并打印出总和。
//n is required number of iterations.
#include<stdio.h>
#include<conio.h>
#include<math.h>
double integral (int a,int b,int c,int d,int e,int n)
int main()
{
double a, b, c, d, e, n;
printf("Please select values for y=ax^2+bx+c");
printf("Please select value for a");
scanf("%d", &a);
printf("Please select value for b");
scanf("%d", &b);
printf("Please select value for c");
scanf("%d", &c);
printf("Please select value for the upper limit");
scanf("%d", &d);
printf("Please select value for the lower limit");
scanf("%d", &e);
printf("Please select the number of rectangles for the Simpson's Rule (Input 100)");
scanf("%n", &n);
int i;
double sum=0,length=(double)(d-e)/(n),ad,bd,cd,dd;
ad=(double)a;
bd=(double)b;
cd=(double)c;
dd=(double)d;
for (i=0;i<n;i++)
{
sum+=(ad*(dd*dd+2*dd*length*i+length*length*i*i)+bd*(dd+length*i)+cd)*length;
printf("the value is = %d",sum);
}
return sum;
}
它shouldve一直的scanf( “%d”,&e);我有麻烦的代码在后整合。 – 2015-04-01 20:45:35