




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
RecursiveRecursion,aprocedureorsubroutine,implementedinaprogramminglanguage,whoseimplementationreferencesitself.Theimportanceoftherecursive1Sometimesrecursionhelpsyoutodesignsimplerandmorereadablecode.2Theadvantageisthatyoudonothavetopreservestateoneachiteration.3Itisespeciallyrelevantforrecursivedatastructures(liketrees)orrecursivealgorithms.UsingRecursiveinC:
Followingisthesourcecodeforafunctioncalledfactorial().Thisfunctiontakesoneparameter
numberandreturnsthenumberfactorial:
一下是factorial()調(diào)用的函數(shù)的源代碼。該函數(shù)有一個(gè)參數(shù)number,并返回number的階乘。#include"stdio.h"http://functionreturningthedata'sfactorial.intfactorial(intnumber)//factorial(5)=5*4*3*2*1{ if(number==1)
return1; else
returnnumber*factorial(number-1);}intfactorial(intnumber);//FunctionDeclarationvoidmain(void){ inti;//localvariabledeclaration printf("Pleaseinputaninteger=>"); scanf("%d",&i); printf("Theinteger'sfactorial=>%d",factorial(i));
//callingthe'factorial'functiontogetaresult. getchar();getchar();}CPointers
Apointerisavariablewhosevalueistheaddressofanothervariable.Likeanyvariableorconstant,youmustdeclareapointerbeforeyoucanworkwithit.Thegeneralformofapointervariabledeclarationis:
type*var-name;
指針是一個(gè)變量,它的值是另一個(gè)變量的地址。像任何變量或常量,你必須聲明一個(gè)指針之前,你可以使用它。一個(gè)指針變量聲明的一般形式是:類型*VAR-名稱;TheimportanceofthepointerSomeCtasksareperformedmoreeasilywithpointers,andotherCtasks,suchasdynamicmemoryallocation,cannotbeperformedwithoutthem.UsingPointersinC:#include"stdafx.h"voidmain(){ inta,*ptr;
//variabledeclaration,pointervariable
ptr=&a;
//storeaddressofainpointervariable
printf("Pleaseinputaninteger=>");
scanf("%d",&(*ptr));//=scanf("%d",ptr);//printtheaddressstoredinippointervariable printf("theintegeraddress:%p\n",ptr);
//accessthevalueattheaddressavailableinpointer printf("a=%d",*ptr);}UsingPointersandRecursiveFunctioninC//calculate:sum=n+n-1+n-2+...+1//calculateUserinputthemaxnumber'saccumulate.#include"stdafx.h"#defineMAX(a,b)(a>b?a:b)//functionreturningthemaxbetweentwonumbersintassignment(int*p,int*q);//FunctionDeclarationintsum(intm);//FunctionDeclarationvoidmain(void){ intnumber1,number2;//localvariabledeclaration printf("Pleaseinputtwointegers=>"); printf("theMaxintegeraccumulatesum:%d",sum(assignment(&number1,&number2)));
//first:calling"assignment"functiontogetaMaxvalue.
//second:calling"sum"functiontogetresult.}intassignment(int*p,int*q)//functionreturningtheUserinputMaxdata.{ scanf("%d",&(*p));//&(*p)=p scanf("%d",&(*q));//&(*q)=q returnMAX(*p,*q);//callingMAXfunctionandret
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 紗線經(jīng)銷合同范本
- 磁性材料的環(huán)境影響及優(yōu)化策略
- 2025至2030年中國(guó)硬質(zhì)合金木工刀具材料數(shù)據(jù)監(jiān)測(cè)研究報(bào)告
- 創(chuàng)業(yè)團(tuán)隊(duì)合同范本
- 電機(jī)控制器維護(hù)保養(yǎng)的專業(yè)知識(shí)解讀
- 電子商務(wù)教育中的創(chuàng)新創(chuàng)業(yè)教育內(nèi)容設(shè)計(jì)
- 科技產(chǎn)品與藝術(shù)設(shè)計(jì)的融合創(chuàng)新
- 知識(shí)產(chǎn)權(quán)在科技創(chuàng)新中的激勵(lì)作用
- 研究生畢業(yè)論文整體規(guī)劃與答辯流程解析
- 覆土合同范本
- 新編地圖學(xué)教程(第三版)毛贊猷_期末復(fù)習(xí)知識(shí)點(diǎn)總結(jié)
- 部編版語(yǔ)文五年級(jí)下冊(cè)形近字組詞參考
- 經(jīng)銷商授權(quán)協(xié)議合同書(中英文對(duì)照)
- 第三章走向混沌的道路
- 化探野外工作方法及要求
- 2006年事業(yè)單位工資改革工資標(biāo)準(zhǔn)表及套改表2
- 江蘇省特種設(shè)備安全條例2021
- 青島海洋地質(zhì)研究所公開招聘面試答辯PPT課件
- 舉世無(wú)雙的建筑師
- 常見導(dǎo)管的固定與維護(hù)PPT課件
- 白龜湖濕地公園調(diào)研報(bào)告
評(píng)論
0/150
提交評(píng)論