版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
RecursiveRecursion,aprocedureorsubroutine,implementedinaprogramminglanguage,whoseimplementationreferencesitself.Theimportanceoftherecursive1Sometimesrecursionhelpsyoutodesignsimplerandmorereadablecode.2Theadvantageisthatyoudonothavetopreservestateoneachiteration.3Itisespeciallyrelevantforrecursivedatastructures(liketrees)orrecursivealgorithms.UsingRecursiveinC:
Followingisthesourcecodeforafunctioncalledfactorial().Thisfunctiontakesoneparameter
numberandreturnsthenumberfactorial:
一下是factorial()調(diào)用的函數(shù)的源代碼。該函數(shù)有一個參數(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;
指針是一個變量,它的值是另一個變量的地址。像任何變量或常量,你必須聲明一個指針之前,你可以使用它。一個指針變量聲明的一般形式是:類型*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. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年硅鐵合金合作協(xié)議書
- 2024年懸浮床加氫裂化催化劑項目發(fā)展計劃
- 2024年Α-乙酰乳酸脫羧酶項目發(fā)展計劃
- 2024年智能電能表合作協(xié)議書
- 山東省菏澤外國語學(xué)校2024年六年級數(shù)學(xué)第一學(xué)期期末考試模擬試題含解析
- 山東省濟南市商河縣2024年六年級數(shù)學(xué)第一學(xué)期期末質(zhì)量跟蹤監(jiān)視試題含解析
- 山東省濟寧市魚臺縣2024-2025學(xué)年六上數(shù)學(xué)期末質(zhì)量檢測模擬試題含解析
- 山東省臨沂市河?xùn)|區(qū)2024年數(shù)學(xué)四上期末檢測模擬試題含解析
- 山東省青島市城陽區(qū)2024年數(shù)學(xué)六上期末聯(lián)考試題含解析
- 山東省日照市2024-2025學(xué)年數(shù)學(xué)六上期末學(xué)業(yè)水平測試模擬試題含解析
- 申論-鐘君[15HT名師模塊班][81講]講義(1)(1)
- 音標考試試題
- 帶形基礎(chǔ)“T”形接頭增加體積計算
- 5S組織結(jié)構(gòu)圖
- 不同燃料的鍋爐運行成本比較(煤、輕(重)油、液化石油氣、天然氣和電能及二甲醚)
- 影視專業(yè)熱門畢業(yè)論文題目參考
- 樂團樂器購置表
- 部編版六年級道德與法治上冊《我們是場外“代表”》PPT課件
- 北京大學(xué)經(jīng)濟學(xué)課程表
- 道路管網(wǎng)工程的主要施工方法以及技術(shù)措施大全
- [理學(xué)]固體物理-第四章ppt課件
評論
0/150
提交評論