cg_Amaz1ng 2015-09-04 07:38 采纳率: 60%
浏览 2207

C语言 关于用矩形法求定积分

#include"stdio.h"
#include"math.h"
int main(){
double fun1(double x);
double fun2(double x);
double fun3(double x);
double calc(double a,double b,double (*p)(double));
int type;
double a,b;
double (*p)(double);
printf("请输入序号:\n1、sin\n2、cos\n3、exp\n0、退出\n");
scanf("%d",&type);
while(type=4){
printf("输入错误,重新输入\n");
scanf("%d",&type);
}
switch(type){
case 1:p=fun1;
break;
case 2:p=fun2;
break;
case 3:p=fun3;
break;
case 0:return 0;
break;
}
printf("输入积分下限:");
scanf("%lf",&a);
printf("输入积分上限:");
scanf("%lf",&b);
printf("%lf\n",calc(a,b,p));
return 0;
}

double fun1(double x){

return sin(x);
}
double fun2(double x){
return cos(x);
}
double fun3(double x){
return exp(x);
}
double calc(double a,double b,double (*p)(double)){
double length,i,sum=0,size;
length=(b-a)/10000000;
for(i=a;i<b;i+=length){
size=(*p)(i)*length;
sum+=size;
}
return sum;
}

当我使用exp的时候,计算结果正确,而使用sin 和 cos 则不行,请问哪里出了错?

  • 写回答

3条回答 默认 最新

  • Robot-C 2015-09-04 07:41
    关注


    矩形法求定积分的通用函数;求Fsinx,Fcos,Fexp;
    #include
    #include
    int main()
    {
     float intergral(float (*)(float),float,float,int);//对integral 的声明;
     float fsin(float);//fsin 函数的声明;
     float fcos(float);//fcos 函数声明
    答案就在这里:矩形法求定积分;
    ----------------------你好,人类,我是来自CSDN星球的问答机器人小C,以上是依据我对问题的理解给出的答案,如果解决了你的问题,望采纳。

    评论

报告相同问题?

悬赏问题

  • ¥15 python天天向上类似问题,但没有清零
  • ¥30 3天&7天&&15天&销量如何统计同一行
  • ¥30 帮我写一段可以读取LD2450数据并计算距离的Arduino代码
  • ¥15 C#调用python代码(python带有库)
  • ¥15 矩阵加法的规则是两个矩阵中对应位置的数的绝对值进行加和
  • ¥15 活动选择题。最多可以参加几个项目?
  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)