關(guān)于PHP遞歸算法和應(yīng)用方法介紹_PHP教程
推薦:PHP 讀取Postgresql中的數(shù)組PHP 讀取Postgresql中的數(shù)組,需要的朋友可以參考一下
PHP作為開(kāi)發(fā)動(dòng)態(tài)頁(yè)面WEB的首選技術(shù),對(duì)于它的基礎(chǔ)知識(shí)我們一定要牢記,這讓才能有助于編程。我們一起來(lái)看看PHP遞歸算法是怎么回事吧。
1、調(diào)用子程序的含義:
當(dāng)主程序執(zhí)行到調(diào)用子程序A語(yǔ)句時(shí),系統(tǒng)保存一些必要的現(xiàn)場(chǎng)數(shù)據(jù),然后執(zhí)行類似于BASIC語(yǔ)言的GOTO語(yǔ)句,跳轉(zhuǎn)到子程序A(為了說(shuō)得簡(jiǎn)單些,我這里忽略了參數(shù)傳遞這個(gè)過(guò)程)。當(dāng)子程序A執(zhí)行到調(diào)用子程序B語(yǔ)句時(shí),系統(tǒng)作法如上,跳轉(zhuǎn)到子程序B。子程序B執(zhí)行完所有語(yǔ)句后,跳轉(zhuǎn)回子程序A調(diào)用子程序B語(yǔ)句的下一條語(yǔ)句(我這又忽略了返回值處理)子程序A執(zhí)行完后,跳轉(zhuǎn)回主程序調(diào)用子程序A語(yǔ)句的下一條語(yǔ)句,主程序執(zhí)行到結(jié)束。做個(gè)比較:我在吃飯(執(zhí)行主程序)吃到一半時(shí),某人叫我(執(zhí)行子程序A),話正說(shuō)到一半,電話又響了起來(lái)(執(zhí)行子程序B),我只要先接完電話,再和某人把話說(shuō)完,最后把飯吃完(我這飯吃得也夠累的了J)。
2、認(rèn)識(shí)遞歸函數(shù)
我們?cè)诟咧袝r(shí)都學(xué)過(guò)數(shù)學(xué)歸納法,PHP遞歸算法例如:
求 n!我們可以把n!這么定義也就是說(shuō)要求3!,我們必須先求出2!,要求2!,必須先求1!,要求1!,就必須先求0!,而0!=1,所以1!=0!*1=1,再進(jìn)而求2!,3!。分別用函數(shù)表示,我們可以觀察到,除計(jì)算0!子程序外,其他的子程序基本相似,我們可以設(shè)計(jì)這么一個(gè)子程序:
int factorial(int i){
int res;
res=factorial(I-1)*i;
return res;
}
那么當(dāng)執(zhí)行主程序語(yǔ)句s=factorial(3)時(shí),就會(huì)執(zhí)行factorial(3),但在執(zhí)行factorial(3),又會(huì)調(diào)用 factorial(2),這時(shí)大家要注意,factorial(3)和factorial(2)雖然是同一個(gè)代碼段,但在內(nèi)存中它的數(shù)據(jù)區(qū)是兩份!而執(zhí)行factorial(2)時(shí)又會(huì)調(diào)用factorial(1),執(zhí)行factorial(1)時(shí)又會(huì)調(diào)用factorial(0),每調(diào)用一次 factorial函數(shù),它就會(huì)在內(nèi)存中新增一個(gè)數(shù)據(jù)區(qū),那么這些復(fù)制了多份的函數(shù)大家可以把它看成是多個(gè)不同名的函數(shù)來(lái)理解;但我們這個(gè)函數(shù)有點(diǎn)問(wèn)題,在執(zhí)行factorial(0)時(shí),它又會(huì)調(diào)用factorial(-1)。。。造成死循環(huán),也就是說(shuō),在factorial函數(shù)中,我們要在適當(dāng)?shù)臅r(shí)候保證不再調(diào)用該函數(shù),也就是不執(zhí)行res=factorial(I-1)*i;這條調(diào)用語(yǔ)句。所以函數(shù)要改成:
int factorial(int i){
int res;
if (I>0) res=factorial(I-1)*i; else res=1;
return res;
}
3、如何考慮用PHP遞歸算法來(lái)解決問(wèn)題
例:求s=1+2+3+4+5+6+……+n本來(lái)這個(gè)問(wèn)題我們過(guò)去常用循環(huán)累加的方法。而這里如要用遞歸的方法,必須考慮兩點(diǎn):
1) 能否把問(wèn)題轉(zhuǎn)化成遞歸形式的描述;
2) 是否有遞歸結(jié)束的邊界條件。
顯然遞歸的兩個(gè)條件都有了:
1) s(n) =s(n-1)+n
2) s(1)=1
所以源程序?yàn)椋?/P>
int progression(int n){
int res;
if (n=1 )res=1 else res=progression(n-1)+n;
return res;
}
4、遞歸的應(yīng)用
中序遍歷二叉樹
void inorder (BinTree T){
if (T){
inorder(T->lchild);
printf(“%c”,T->data);
inorder(T->rchild);
}
}
分享:php簡(jiǎn)單開(kāi)啟gzip壓縮方法(zlib.output_compression)網(wǎng)上的教程基本是你抄我來(lái)我抄他,不外乎加頭加尾或者自構(gòu)函數(shù)兩種寫法。實(shí)際上每個(gè)php頁(yè)面都要去加代碼——當(dāng)然也可以include引用,不過(guò)總顯得略微麻煩
- PHPNOW安裝Memcached擴(kuò)展方法詳解
- php記錄頁(yè)面代碼執(zhí)行時(shí)間
- PHP中獎(jiǎng)概率的抽獎(jiǎng)算法程序代碼
- apache設(shè)置靜態(tài)文件緩存方法介紹
- php對(duì)圖像的各種處理函數(shù)代碼小結(jié)
- PHP 關(guān)于訪問(wèn)控制的和運(yùn)算符優(yōu)先級(jí)介紹
- 關(guān)于PHP語(yǔ)言構(gòu)造器介紹
- php/js獲取客戶端mac地址的實(shí)現(xiàn)代碼
- php5.5新數(shù)組函數(shù)array_column使用
- PHP preg_match的匹配多國(guó)語(yǔ)言的技巧
- php 中序列化和json使用介紹
- php采集文章中的圖片獲取替換到本地
PHP教程Rss訂閱編程教程搜索
PHP教程推薦
- PHP初學(xué)者頭疼問(wèn)題總結(jié)
- 淺談開(kāi)發(fā)PHP網(wǎng)站要掌握的技巧
- AJAX在PHP中的簡(jiǎn)單使用
- 解析在PHP中使用mysqli擴(kuò)展庫(kù)對(duì)mysql的操作
- LotusPhp筆記之:基于ObjectUtil組件的使用分析
- PHP讀取RSS feed源代碼(帶注釋,可讀取多個(gè)源)
- 創(chuàng)建論壇專業(yè)知識(shí)庫(kù) HDWiki(For Discuz!)V1.0正式版發(fā)布
- 基于PHP Web開(kāi)發(fā)MVC框架的Smarty使用說(shuō)明
- php插入中文到sql server 2008里出現(xiàn)亂碼的解決辦法
- php正則匹配獲取指定url網(wǎng)頁(yè)頁(yè)面超級(jí)鏈接地址
- 相關(guān)鏈接:
- 教程說(shuō)明:
PHP教程-關(guān)于PHP遞歸算法和應(yīng)用方法介紹。