




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、安徽中医药大学题目:Romberg求积法c语言编程姓名:杨撞撞学号:13713042班级:13医软(1)班目录1简介2计算公式3算法描述4程序流程图5算法程序表示6算法结果截图l 1.简介龙贝格求积公式也称为逐次分半加速法。它是在梯形公式、辛普森公式和柯特斯公式之间的关系的基础上,构造出一种加速计算积分的方法。 作为一种外推算法, 它在不增加计算量的前提下提高了误差的精度.在等距基点的情况下,用计算机计算积分值通常都采用把区间逐次分半的方法进行。这样,前一次分割得到的函数值在分半以后仍可被利用,且易于编程。l 2.计算公式梯形公式复化辛普森公式复化科特斯公式 龙贝格求积公式其对应的公式为:T2
2、n=1/2(Tn+Hn) (梯形公式)Sn=4/(4-1)T2n-1(4-1)Tn (辛普森公式)Cn=42/(42-1)S2n-1/(42-1)Sn (柯特斯公式)Rn=43/(43-1)C2n-1/(43-1)Cn (龙贝格求积法公式)l 3.算法描述3.1龙贝格算法基本描述先算出T0(0),从而计算出T0(1),以此类推,直到计算出|T0(0)-Tn-1(0)|<e即可利用加速推算公式推算出结果。 3.2龙贝格算法程序包步骤 1.输入积分上限 2输入程序下限3输入区间等分数4输入要求的函数5计算出所求函数的积分,分别是:u 复化梯形求积结果u 辛普森求积结果u 柯特斯求积结果u 龙
3、贝格求积结果 l 4.程序流程图例题:用Romberg方法计算积分I=ò0¹sin(x)/xdx的相关算法流程图表示如下图l 5.算法程序表示#include<stdio.h>#include<math.h>#define A(x)(sin(x)/x) /宏定义若干常用函数A,B,C,D,E,G#define B(x)(cos(x*x+2*x+1)#define C(x)(atan(sqrt(x*x+1)#define D(x)(sqrt(exp(x)+sin(2*x)#define E(x)(x*x*x+3*x*x+5)#define G(x)(l
4、og10(x)/pow(2,x)double t20,s20,c20,r20;/定义全局数组double dh,fan,a,b,m; /定义全局变量int jj=0;char hs;double F(double x) /用switch调用若干被积函数switch(hs)case 'A':fan=A(x);break;case 'B':fan=B(x);break;case 'C':fan=C(x);break;case 'D':fan=D(x);break;case 'E':fan=E(x);break;case
5、 'G':fan=G(x);break;default :printf("输入错误!");return(fan);/返回被积函数值double H(int i) /求和函数并返回和SUMint j; double zh,SUM=0.0; /定义求和变量SUM并赋初值for(j=1;j<=pow(2,i-1);j+)zh=(a+(2*j-1)*(b-a)/pow(2,i); SUM=SUM+F(zh); /调用F(x)函数 SUM=(b-a)*SUM/pow(2,i);return(SUM);double Txing(int k) /梯形公式if(k=0
6、) dh=tjj=(b-a)/2)*(F(a)+F(b); /分半次数为零时T形公式求积else dh=0.5*Txing(k-1)+H(k); /Txing函数递归调用循环输出并返回dh t+jj=dh; m=pow(2,jj);printf("T%0.0lf=%0.7lft",m,tjj);/输出并返回dhreturn(dh);double Simpson(int k) /辛普森公式int i,j; Txing(k); /调用梯形公式for(i=0;i<=k-1;i+)si=(4.0*ti+1-ti)/3.0; /递推辛普森公式 printf("n&qu
7、ot;);for(j=0;j<=k-1;j+) /循环输出 m=pow(2,j);printf("S%0.0lf=%0.7lf",m,sj); printf("t");return(sk-1); /返回最后一个值sk-1double Cotes(int k) /科特斯公式int i,j; Simpson(k);for(i=0;i<=k-2;i+)ci=(16.0*si+1-si)/15.0; /递推科特斯公式 printf("n");for(j=0;j<=k-2;j+) /循环输出m=pow(2,j);printf(
8、"C%0.0lf=%0.7lft",m,cj);return(ck-2); /返回最后一个值ck-2double Romberg(int k) /隆贝格公式int i,j; /调用科特斯公式 Cotes(k); for(i=0;i<=k-3;i+) ri=(64.0*ci+1-ci)/63.0; /递推隆贝格公式printf("n");for(j=0;j<=k-3;j+) /循环输出 m=pow(2,j); printf("R%0.0lf=%0.7lft",m,rj); printf("n");retu
9、rn(rk-3); /返回最后一个值rk-3main()int k;char y;printf("请从以下公式中选择积分函数:n");printf("A: sin(x)/(x)tB:cos(x2+2x+1)tC:atan(sqrt(x2+1)nn");printf("D:sqrt(ex+sin(2x)tE:x3+3*x2+5tG:log10(x)/pow(2,x)nn");printf("请选择函数F(x)(大写):n");scanf("%c",&hs);getchar();printf
10、("请输入您选用的求积公式第一个字母(大写):n");y=getchar();switch(y) /根据输入的大写字母判断所选求积公式 case 'T':printf("请输入分半次数:n"); scanf("%d",&k); printf("请输入积分区间a,b且(a<b):n"); scanf("%lf,%lf",&a,&b); if(a=0) a=0.0000000001; /输入当积分区间为零时默认为一极小数 printf("-n&
11、quot;); printf("nTxing=%0.7fn",Txing(k);break; /输出计算结果小数点后保留7位 case 'S':printf("请输入分半次数大于等于1的正整数:n"); scanf("%d",&k); printf("请输入积分区间a,b且(a<b):n"); scanf("%lf,%lf",&a,&b); if(a=0) a=0.0000000001; /输入当积分区间为零时默认为一极小数 printf("
12、;-n"); printf("Simpson=%0.7fn",Simpson(k);break; /输出计算结果小数点后保留7位case 'C':printf("请输入分半次数大于等于2的正整数:n"); scanf("%d",&k); printf("请输入积分区间a,b且(a<b):n"); scanf("%lf,%lf",&a,&b); if(a=0) a=0.0000000001; /输入当积分区间为零时默认为一极小数 printf("-n"); printf("Cotes=%0.7fn",Cotes(k);break; /输出计算结果小数点后保留7位case 'R':printf("请输入分半次数大于等于3的正整数:n"); scanf("%d",&k); printf("请输入积分区间a,b且(a<b):n"); scanf("%lf,%lf",&a,&b); if(a=0) a=0.0000000001; /输入
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年福建南平武夷有轨电车有限公司社会招聘考前自测高频考点模拟试题及答案详解参考
- 2025年福建省龙岩市武平县招聘教育卫生干部10人模拟试卷及参考答案详解
- 2025湖南澄迈县农业技术推广中心招聘见习生7人考前自测高频考点模拟试题及一套答案详解
- 2025广东广州市黄埔区人民政府萝岗街道办事处招聘政府聘员2人模拟试卷附答案详解
- 2025广西卫生职业技术学院公开招聘高层次人才22人考前自测高频考点模拟试题参考答案详解
- 2025北京海淀青龙桥社区卫生服务中心面向社会招聘2人考前自测高频考点模拟试题及答案详解(夺冠系列)
- 2025中文版运输合同范本
- 2025河北唐山市市直事业单位招聘工作人员277人模拟试卷(含答案详解)
- 2025年山东法官培训学院公开招聘人员模拟试卷及参考答案详解一套
- 2025贵州剑河县农村集体经济组织选聘职业经理人(总经理)17人考前自测高频考点模拟试题及答案详解1套
- 2025少先队基础知识题库(含答案)
- 人教版九年级物理上-各单元综合测试卷含答案共五套
- 三折页设计课件
- 防诈骗消防安全知识培训课件
- 数据标注课件
- 山河已无恙+吾辈当自强+课件-2025-2026学年高二上学期用《南京照相馆》和731上一节思政课
- 2025至2030年川渝地区成品油行业市场运行现状及未来发展预测报告
- 减肥与能量代谢课件
- 《三借芭蕉扇》课件
- 综合实践课程培训大纲
- 半导体公司内部管理制度
评论
0/150
提交评论