C语言-写一个用矩形法求定积分的通用函数,分别求积分区间为[0,1]sinx,cosx,e的x方的定积分

一、题目要求:

二、思路

①数学方面:矩形法求定积分的公式

将积分图形划分成为指定数量的矩形,求取各个矩形的面积,然后最终进行累加得到结果

1.积分区间:

[num1, num2]

2.分割数量:count

每个矩形的边长:dx=(num2-num1)/count

3.被积分函数:

f(x)(f-对应不同的被积分函数 sin/cos/exp)(x=num1 + dx*n) 计算矩形高度

4.求取每个矩形的面积进行累加:S=S1 +S2 +...+ Sn

②编程方面:函数指针

在代码中,要调用一个函数,其实就是就是让cpu执行指令的时候,跳转到指定的位置加载指令进行执行

三、程序:

c 复制代码
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include<math.h>

double integral(double num1, double num2, int count, double (*handler)(double))
{
	double dx = (num2 - num1) / count;
	double res = 0;
	for (int i = 0; i < count; i++)
	{
		double dh = handler(num1 + dx * i);
		res += dx * dh;
	}
	return res;
}
int main()
{
	printf("请输入积分区间[num1,num2]:");
	double num1, num2;
	scanf("%lf%lf", &num1, &num2);
	printf("请输入分割数量:");
	int count;
	scanf("%d", &count);
	printf("请输入被积分函数<1-sin,2-cos,3-exp>:");
	int choice;
	scanf("%d", &choice);

	double(*var[4])(double) = { NULL,sin,cos,exp };
	double res = integral(num1, num2, count, var[choice]);
	printf("定积分结果:%lf\n", res);
	return 0;
}

四、运行结果:

相关推荐
Lv1177008几秒前
初识Visual Studio中的 WinForm
开发语言·ide·笔记·c#·visual studio
superman超哥3 分钟前
Rust Cargo Build 编译流程:从源码到二进制的完整旅程
开发语言·后端·rust·编译流程·cargo build·从源码到二进制
永远前进不waiting9 分钟前
C语言复习——2
c语言·开发语言
枫叶丹415 分钟前
ModelEngine应用编排创新实践:通过可视化编排构建大模型应用工作流
开发语言·前端·人工智能·modelengine
net3m3334 分钟前
websocket下发mp3帧数据时一个包被分包为几个子包而导致mp3解码失败而播放卡顿有杂音或断播的解决方法
开发语言·数据库·python
38242782737 分钟前
python3网络爬虫开发实战 第2版:使用aiohttp
开发语言·爬虫·python
m0_6726565443 分钟前
JavaScript性能优化实战技术文章大纲
开发语言·javascript·性能优化
Yang-Never44 分钟前
Android 内存泄漏 -> LiveData如何解决ViewMode和Activity/Fragment之间的内存泄漏
android·java·开发语言·kotlin·android studio
Smartdaili China1 小时前
如何在桌面和移动设备上修复YouTube错误400
开发语言·php·error·youtube·移动·住宅ip·错误400
持梦远方1 小时前
持梦行文本编辑器(cmyfEdit):架构设计与十大核心功能实现详解
开发语言·数据结构·c++·算法·microsoft·visual studio