梯形法求定积分(C)

养成好习惯,点个赞 再走;有问题,欢迎私信、评论,我看到都会回复的

文章目录

梯形法求定积分

假设

  • f(x) = x2 + 5x + 7
  • 定积分下限为0,上积分上限为1
  • 梯形法求定积分就是一种面积计算法,将定积分以某个标准划分成很多部分,把每个小部分的面积计算出来,然后累加
  • 我这里,将定积分以x轴划分了1000份(划分的越多,所得值越精确),所以在积分下限和积分上限的基础上,将划分的单位宽度n = 0.001
  • 然后,每个划分单位的宽度都为0.001,高度取左右边界高度的平均值
  • 计算高度:就是将变量带入函数 f 中即可
#include<stdio.h>

int main()
{
    //函数声明
	float de_integral(float a, float b, float (*p)(float));
    float f(float x); 

    //输出
	printf("%f", de_integral(0, 1, f));
	return 0;
}

//构建一个函数
float f(float x){
	return (x*x + 5*x + 7);
}

//计算定积分
float de_integral(float a, float b, float (*p)(float)){//积分下限a,积分上限b
	int i, l;        //梯形法求定积分
	float n = 0.001, s = 0;//n表示划分的单位宽度,n是矩形的宽度 
	l = (b - a) / n;    //l表示有多少个单位宽度 
	for(i = 0; i < l; i++) s += ( (*p)(a + n*i) + (*p)(a + n*(i+1)) ) * n / 2;
	return s;
}

输出:

9.820334

C语言入门题目文章导航:

  1. 素数(C)
  2. 水仙花数(C)
  3. 斐波那契数列(C)
  4. 完数(C)
  5. 阶乘(C)
  6. 直角杨辉三角形(C)
  7. 大写字母、小写字母、ASCII码(C)
  8. 输入一个字符,找出他的前驱字符和后继字符(C)
  9. 最大数、最小数(C)
  10. 百钱买百鸡(C语言,枚举法)
  11. 辗转相除法求最大公约数,利用最大公约数求最小公倍数(C)
  12. 输入一个年份和一个月份,输出该年此月天数;知道日期,计算该日是本年的第几天(C)
  13. 输入一个不多于4位的正整数,求它的位数,并按逆序输出各位数字(C)
  14. 利用二维数组求方阵的主次对角线之和(C)
  15. 在一个二维数组中找出最小数及其所在的行和列(C)
  16. 找出一个二维数组中的鞍点(C)
  17. 删除指定字符串的指定字符(C)
  18. 字符串(C)
  19. 条件判断语句1(C)
  20. 条件判断语句2(C)
  21. 圆、三角形、正方形、长方体、计算1到100的和、和差积商、平均值
  22. 输入三个整数,要求程序把数据按从小到大的顺序放入x y z中,然后输出(C)
  23. 18个数围成一圈,求相邻三数之和最大数(C)
  24. 本篇文章
  25. 学生与课程的综合问题(C)
  • 27
    点赞
  • 95
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值