C++实现龙贝格求积分算法

article/2025/8/21 19:22:36

1. 算法原理简介

T(0)=(b-a)(f(a)+f(b))/2;
H(0)=(b-a)·f( (a+b)/2 );
T(i)=(T(i-1)+H(i-1))/2。
T(i) 的语义是将积分区间做 2i 等分时复化梯形求积分公式算出的近似值。
H(i) 的语义是将积分区间做 2i 等分时,将每个小区间的长度乘该小区间中点处函数值的乘积进行累加求和的结果。

生成 i>=j 的积分近似值表 R(i, j)具体计算如下:.

  • R(i,0)=T(i)=(T(i-1)+H(i-1))/2,i>=0,T(i)为区间逐次减半递推梯形求积分公式算出的结果;
  • R(i,1)=S(i),i>=1,S(i)为由T(i)、T(i-1)联合递推得出的区间逐次减半递推辛普森求积分公式算出的结果;
  • R(i,2) = B(i),i>=2,B(i) 为由S(i)、S(i-1)联合递推得出布尔求积分公式算出的结果;
    归纳总结有如下递推关系式:

在这里插入图片描述

由上面递推关系式计算积分近似值 R(i, j)构成三角表,循环结束条件 |R(i, i)-R(i-1, i-1)|< eps成立时,则以 R(i, i) 作为最终的积分近似值,否则继续循环计算。

2. 应用实例

用龙贝格积分法计算积分:
在这里插入图片描述

3. 程序代码

#include <iostream>
#include <cmath>
using namespace std;
#define N 20
#define MAX 10     //数组存的最大行数
#define a 0    //积分上限
#define b 1      //积分下限
#define eps 1e-6 //精度double f(double x)//所求积分公式
{	return 4 / (1 + x * x);
}double ComputeT(double aa, double bb, long int n)//复化梯形公式
{	int i;	double sum = 0, h = (bb - aa) / n;	for (i = 1; i < n; i++)	{		sum += f(aa + i * h);	}sum += (f(aa) + f(bb)) / 2;return h * sum;
}double f2(double x)
{	return x * x;
}int main()
{	cout << "被积函数 f = 4 / (1 + x * x)" << endl;	cout << "积分区间为(0,1)" << endl;	cout << "精度为1e-6" << endl;	int i;	long int n = N, m = 0;	double T[MAX + 1][2];	T[0][1] = ComputeT(a, b, n);	n *= 2;	for (m = 1; m < MAX; m++)	{		for (i = 0; i < m; i++)		{			T[i][0] = T[i][1];		}		T[0][1] = ComputeT(a, b, n);		n *= 2;		for (i = 1; i <= m; i++) //T的m(h)		{			T[i][1] = T[i - 1][1] + (T[i - 1][1] - T[i - 1][0]) / (pow(2, 2 * m) - 1);		}		if ((T[m - 1][1] < T[m][1] + eps) && (T[m - 1][1] > T[m][1] - eps))		{			cout << "积分值为:" << T[m][1] << endl;			return 0;		}	}cout << "此题无解!" << endl;	return 0;
} 

4.运行结果

在这里插入图片描述


http://chatgpt.dhexx.cn/article/3x6Kw4M6.shtml

相关文章

c#求定积分

步骤&#xff1a; 1 安装和使用NuGet插件 教程链接&#xff1a;https://blog.csdn.net/qq_36456952/article/details/55252913 2 安装 C# 科学计算库 Math.NET Numerics 教程链接: https://blog.csdn.net/heray1990/article/details/72467304 注意&#xff1a;在安装 C#…

人工智能数学基础---不定积分4:有理函数求积分的方法

一、引言 在《人工智能数学基础–不定积分2&#xff1a;利用换元法求不定积分》、《人工智能数学基础—不定积分3&#xff1a;分部积分法》分别介绍了换元积分法和分步积分法。但有些函数表达式很复杂&#xff0c;如果直接用换元积分法和分步积分法不好计算积分&#xff0c;这…

求积分方法及积分知识点-----专升本

求积分 一般&#xff08;常见&#xff09;求不定积分方法 一般&#xff08;常见&#xff09;定积分方法 带三角函数的求积分 凑微分法&#xff0c;拆开&#xff0c;三角代换&#xff0c;分部积分&#xff0c;整体法&#xff0c; 倒三角变正三角&#xff0c;奇拆偶降 几分之一圆…

二维数组、指针详解

二维数组、指针详解&#xff1a; 目录 二维数组、指针详解&#xff1a; 1.研究二维数组的表示。 2.现在研究关于二维数组和指针的关系 1.研究二维数组的表示。 首先&#xff0c;用代码运行进行测试&#xff0c;验证的相关结果&#xff0c; // C.cpp : 定义控制台应用程序…

二维数组与指针

转载自&#xff1a;https://www.cnblogs.com/chenyangyao/p/5222696.html 声明&#xff1a;本文为原创博文&#xff0c;如有转载&#xff0c;请注明出处。若本文有编辑错误、概念错误或者逻辑错误&#xff0c;请予以指正&#xff0c;谢谢。 指针与数组是C/C编程中非常重要的元…

二维数组指针,指针数组与数组指针的区别,一看就懂

目录 一.二维数组基本概念 二.指针数组和数组指针的区别 1.数组指针 2.指针数组 3.总结 三.二维数组的首地址和数组名 四.二维数组如何运用指针&#xff1f; 五.代码分析,加深了解。 一.二维数组基本概念 二维数组在概念上是二维的&#xff0c;有行和列&#xff0c;但在…

二维数组与数组指针详解

二维数组 深入理解二维数组 首先定义一个二维数组 int a[2][3]{{1,2,3},{4,5,6}}; #or int a[2][2]{1,2,3,4};新的理解&#xff1a;我们可以这样认为&#xff0c;a可以看作是一个一维数组&#xff0c;包含2个元素&#xff0c;每个元素恰好是包含3个整型的元素&#xff0c;a这个…

c语言——二维指针数组

1 一维度数组与指针 1.1一维数组元素在内存分布 #include<stdio.h> #include<stdlib.h> #include<string.h>#define ARRAY_SIZE 8void main() {int data[ARRAY_SIZE]{0,1,2,3,4,5,6,7};int i;printf("data address:0x%-8x\r\n",data);for(i0; i&l…

c++二维数组指针

&#xff11;.定义指针指向二维数组 为了方便根据用户输入动态定义二维数组的行和列&#xff0c;引入变量rowsNum(行)&#xff0c;colsNum(列&#xff09;。 以定义&#xff15;行&#xff14;列的二维数组为例&#xff0c; int rowsNum 4;int colsNum 5;float** a new fl…

二维数组名是指针的指针吗?

我们知道一维数组名是常量指针&#xff0c;我们可以将一维数组名赋给一个指针类型再对一维数组进行相关的操作&#xff0c;那二维数组名又是什么&#xff1f; 我们这样初始化一个二维数组int A[3][3]{1,2,3,4,5,6,7,8}或者为int A[3][3]{ {1,2,3},{4,5,6}&#xff0c;{7,8,9}}…

c++二维数组中指针详解

二维数组 a[2][3]{{1,2,3},{4,5,6}};指针p有如下几种表达形式&#xff1a; 1 方式一&#xff1a;int (*p)[3]a (或&a[0]&#xff09;; 一定要加上括号&#xff0c;因为[]的优先级高于*&#xff1b;意思是定义一个指向3个int类型变量的指针。p代表二维数组中第一个…

C语言 二维数组和指针

二维数组可以看成是元素为一维数组的数组&#xff0c;假设有一个三行四列的二维数组a&#xff0c;它定义为&#xff1a; int a[3][4] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12 }; a 是二维数组名。a 数组包含 3 行&#xff0c;即 3 个行元素&#xff1a;a[0]&#xff0c;a[1]…

C/C++指向二维数组的指针

1. 二维数组 设有整型二维数组a[3][4]如下&#xff1a;     0 1 2 3     4 5 6 7     8 9 10 11   它的定义为&#xff1a;       int a[3][4]{{0,1,2,3},{4,5,6,7},{8,9,10,11}}  设数组a的首地址为1000&#xff0c;各下标变量的首地址及其值如图所…

二维数组与二级指针

关于二维数组与二级指针那些你必须知道的事 首先,来看一个例子一个error嗯,我是解析指针数组与数组指针 首先,来看一个例子 #include <iostream>using namespace std;int main(void) {int **p;pnew int*[5];for(int i0;i<5;i){p[i]new int[5];}return 0; }不严格地说…

C语言二维数组指针用法

目录 题目 背景概念梳理 一维线性 数组指针 指针步长 数组名与指向其的指针变量名等价 数组的初始化与取元素 数组指针转换关系 解题过程 选项A&#xff1a;* (( * prt1)[2]) 选项B&#xff1a;* ( * (p5)) 选项C&#xff1a;( * prt1)2 选项D&#xff1a; * ( * (…

二维数组指针表示,C语言指针引用二维数组详解

指针变量可以指向一维数组中的元素&#xff0c;当然也就可以指向二维数组中的元素。但是在概念和使用方法上&#xff0c;二维数组的指针比一维数组的指针要复杂一些。要理解指针和二维数组的关系首先要记住一句话&#xff1a;二维数组就是一维数组&#xff0c;这句话该怎么理解…

C语言二维数组指针(指向二维数组的指针)详解

声明&#xff01;本文转载仅为方便学习使用&#xff01; 如有需要&#xff0c;请访问C语言指针数组&#xff08;数组每个元素都是指针&#xff09;详解C语言二维数组指针&#xff08;指向二维数组的指针&#xff09;详解 二维数组在概念上是二维的&#xff0c;有行和列&#x…

c语言 二维数组指针

文章目录 前言一、二维数组指针的定义&#xff1a;二、二维数组指针遍历数组元素&#xff1a;总结 前言 前面我们讲了一维数组指针&#xff0c;今天我们讲一下二维数组指针。 一、二维数组指针的定义&#xff1a; 概述&#xff1a; 二维数组指针的定义就是把一维数组换成二维…

关于二维数组,二维数组指针

最近学习指针&#xff0c;一不小心就掉进了二维数组指针的坑里面&#xff0c;在迷惑了接近一个星期后&#xff0c;我有了以下的总结。&#xff08;希望有大佬看见了能指点指点&#xff0c;我也不知道这么理解到底对不对&#xff0c;虽然我觉得是对的&#xff09; 这是我一开始…

二维数组与指针的关系详解

静态二维数组与指针 我们定义一个二维数组int a[4][3]。 二维数组实际是由多个一维数组组成&#xff0c;在这里&#xff0c;a[3][4]就是由3个长度为4的一维数组组成的二维数组。并且它们在空间上是连续的&#xff0c;相当于一个长为12的一维数组。 这里a&#xff0c;a[i]全部…