版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、安徽中醫(yī)藥大學題目:Romberg求積法c語言編程姓名:楊撞撞學號:13713042班級:13醫(yī)軟(1)班目錄1簡介2計算公式3算法描述4程序流程圖5算法程序表示6算法結果截圖l 1.簡介龍貝格求積公式也稱為逐次分半加速法。它是在梯形公式、辛普森公式和柯特斯公式之間的關系的基礎上,構造出一種加速計算積分的方法。 作為一種外推算法, 它在不增加計算量的前提下提高了誤差的精度.在等距基點的情況下,用計算機計算積分值通常都采用把區(qū)間逐次分半的方法進行。這樣,前一次分割得到的函數(shù)值在分半以后仍可被利用,且易于編程。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輸入?yún)^(qū)間等分數(shù)4輸入要求的函數(shù)5計算出所求函數(shù)的積分,分別是: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) /宏定義若干常用函數(shù)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;/定義全局數(shù)組double dh,fan,a,b,m; /定義全局變量int jj=0;char hs;double F(double x) /用switch調用若干被積函數(shù)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);/返回被積函數(shù)值double H(int i) /求和函數(shù)并返回和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)函數(shù) 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); /分半次數(shù)為零時T形公式求積else dh=0.5*Txing(k-1)+H(k); /Txing函數(shù)遞歸調用循環(huán)輸出并返回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+) /循環(huán)輸出 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+) /循環(huán)輸出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+) /循環(huán)輸出 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("請從以下公式中選擇積分函數(shù):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("請選擇函數(shù)F(x)(大寫):n");scanf("%c",&hs);getchar();printf
10、("請輸入您選用的求積公式第一個字母(大寫):n");y=getchar();switch(y) /根據(jù)輸入的大寫字母判斷所選求積公式 case 'T':printf("請輸入分半次數(shù):n"); scanf("%d",&k); printf("請輸入積分區(qū)間a,b且(a<b):n"); scanf("%lf,%lf",&a,&b); if(a=0) a=0.0000000001; /輸入當積分區(qū)間為零時默認為一極小數(shù) printf("-n&
11、quot;); printf("nTxing=%0.7fn",Txing(k);break; /輸出計算結果小數(shù)點后保留7位 case 'S':printf("請輸入分半次數(shù)大于等于1的正整數(shù):n"); scanf("%d",&k); printf("請輸入積分區(qū)間a,b且(a<b):n"); scanf("%lf,%lf",&a,&b); if(a=0) a=0.0000000001; /輸入當積分區(qū)間為零時默認為一極小數(shù) printf("
12、;-n"); printf("Simpson=%0.7fn",Simpson(k);break; /輸出計算結果小數(shù)點后保留7位case 'C':printf("請輸入分半次數(shù)大于等于2的正整數(shù):n"); scanf("%d",&k); printf("請輸入積分區(qū)間a,b且(a<b):n"); scanf("%lf,%lf",&a,&b); if(a=0) a=0.0000000001; /輸入當積分區(qū)間為零時默認為一極小數(shù) printf("-n"); printf("Cotes=%0.7fn",Cotes(k);break; /輸出計算結果小數(shù)點后保留7位case 'R':printf("請輸入分半次數(shù)大于等于3的正整數(shù):n"); scanf("%d",&k); printf("請輸入積分區(qū)間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. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 玉溪師范學院《數(shù)據(jù)結構與算法》2021-2022學年期末試卷
- 玉溪師范學院《模擬電子技術實驗》2021-2022學年期末試卷
- 道路運輸企業(yè)主要負責人理論考試題及答案-知識題庫
- 國際金融實務教案
- 第一新聲-2024年中國CRM市場研究報告
- 2024年玻璃石材家具項目成效分析報告
- 2024屆河北省石家莊市晉州一中第一次高中畢業(yè)生復習統(tǒng)一檢測試題數(shù)學試題
- 2024屆廣西壯族自治區(qū)桂林市人教A版高中數(shù)學試題高三二輪函數(shù)的圖象與性質測試
- 2024屆廣西欽州市第三中學高三數(shù)學試題3月25日第4周測試題
- 采購合同履約檢查方案
- 廈門市2023-2024學年度第一學期高一年級質量檢測數(shù)學試題參考答案與評分標準
- 人民調解員業(yè)務培訓講稿
- 小學數(shù)學學困生轉化案例
- 結構設計通用規(guī)范(住建部2023年頒布)
- 職業(yè)生涯規(guī)劃就業(yè)賽道個人
- 建筑行業(yè)狀況分析
- 頂板管理知識培訓課件
- 機場運行職業(yè)生涯規(guī)劃書
- 《常見腫瘤的防治》課件
- 老人摔倒該不該扶
- 褐煤分析報告
評論
0/150
提交評論