關(guān)于PHP遞歸算法和應(yīng)用方法介紹
PHP作為開發(fā)動態(tài)頁面WEB的首選技術(shù),對于它的基礎(chǔ)知識我們一定要牢記,這讓才能有助于編程。我們一起來看看PHP遞歸算法是怎么回事吧。
1、調(diào)用子程序的含義:
當(dāng)主程序執(zhí)行到調(diào)用子程序A語句時,系統(tǒng)保存一些必要的現(xiàn)場數(shù)據(jù),然后執(zhí)行類似于BASIC語言的GOTO語句,跳轉(zhuǎn)到子程序A(為了說得簡單些,我這里忽略了參數(shù)傳遞這個過程)。當(dāng)子程序A執(zhí)行到調(diào)用子程序B語句時,系統(tǒng)作法如上,跳轉(zhuǎn)到子程序B。子程序B執(zhí)行完所有語句后,跳轉(zhuǎn)回子程序A調(diào)用子程序B語句的下一條語句(我這又忽略了返回值處理)子程序A執(zhí)行完后,跳轉(zhuǎn)回主程序調(diào)用子程序A語句的下一條語句,主程序執(zhí)行到結(jié)束。做個比較:我在吃飯(執(zhí)行主程序)吃到一半時,某人叫我(執(zhí)行子程序A),話正說到一半,電話又響了起來(執(zhí)行子程序B),我只要先接完電話,再和某人把話說完,最后把飯吃完(我這飯吃得也夠累的了J)。
2、認(rèn)識遞歸函數(shù)
我們在高中時都學(xué)過數(shù)學(xué)歸納法,PHP遞歸算法例如:
求 n!我們可以把n!這么定義也就是說要求3!,我們必須先求出2!,要求2!,必須先求1!,要求1!,就必須先求0!,而0!=1,所以1!=0!*1=1,再進(jìn)而求2!,3!。分別用函數(shù)表示,我們可以觀察到,除計算0!子程序外,其他的子程序基本相似,我們可以設(shè)計這么一個子程序:
int factorial(int i){
int res;
res=factorial(I-1)*i;
return res;
}
那么當(dāng)執(zhí)行主程序語句s=factorial(3)時,就會執(zhí)行factorial(3),但在執(zhí)行factorial(3),又會調(diào)用 factorial(2),這時大家要注意,factorial(3)和factorial(2)雖然是同一個代碼段,但在內(nèi)存中它的數(shù)據(jù)區(qū)是兩份!而執(zhí)行factorial(2)時又會調(diào)用factorial(1),執(zhí)行factorial(1)時又會調(diào)用factorial(0),每調(diào)用一次 factorial函數(shù),它就會在內(nèi)存中新增一個數(shù)據(jù)區(qū),那么這些復(fù)制了多份的函數(shù)大家可以把它看成是多個不同名的函數(shù)來理解;但我們這個函數(shù)有點問題,在執(zhí)行factorial(0)時,它又會調(diào)用factorial(-1)。。。造成死循環(huán),也就是說,在factorial函數(shù)中,我們要在適當(dāng)?shù)臅r候保證不再調(diào)用該函數(shù),也就是不執(zhí)行res=factorial(I-1)*i;這條調(diào)用語句。所以函數(shù)要改成:
int factorial(int i){
int res;
if (I>0) res=factorial(I-1)*i; else res=1;
return res;
}
3、如何考慮用PHP遞歸算法來解決問題
例:求s=1+2+3+4+5+6+……+n本來這個問題我們過去常用循環(huán)累加的方法。而這里如要用遞歸的方法,必須考慮兩點:
1) 能否把問題轉(zhuǎn)化成遞歸形式的描述;
2) 是否有遞歸結(jié)束的邊界條件。
顯然遞歸的兩個條件都有了:
1) s(n) =s(n-1)+n
2) s(1)=1
所以源程序為:
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遞歸的三種常用方式
- php遞歸函數(shù)三種實現(xiàn)方法及如何實現(xiàn)數(shù)字累加
- PHP 無限分類三種方式 非函數(shù)的遞歸調(diào)用!
- php菜單/評論數(shù)據(jù)遞歸分級算法的實現(xiàn)方法
- PHP遞歸算法的簡單實例
- PHP基于遞歸算法解決兔子生兔子問題
- PHP基于非遞歸算法實現(xiàn)先序、中序及后序遍歷二叉樹操作示例
- PHP基于二分法實現(xiàn)數(shù)組查找功能示例【循環(huán)與遞歸算法】
- PHP實現(xiàn)字符串翻轉(zhuǎn)功能的方法【遞歸與循環(huán)算法】
- PHP基于遞歸實現(xiàn)的約瑟夫環(huán)算法示例
- PHP使用遞歸算法無限遍歷數(shù)組示例
- php獲得文件夾下所有文件的遞歸算法的簡單實例
- PHP二分查找算法示例【遞歸與非遞歸方法】
- PHP冒泡算法詳解(遞歸實現(xiàn))
- PHP遞歸算法的詳細(xì)示例分析
- php全排列遞歸算法代碼
- php實現(xiàn)遞歸的三種基本方式
相關(guān)文章
Laravel 數(shù)據(jù)庫加密及數(shù)據(jù)庫表前綴配置方法
今天小編就為大家分享一篇Laravel 數(shù)據(jù)庫加密及數(shù)據(jù)庫表前綴配置方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10ThinkPHP的截取字符串函數(shù)無法顯示省略號的解決方法
這篇文章主要介紹了ThinkPHP的截取字符串函數(shù)無法顯示省略號的解決方法,需要的朋友可以參考下2014-06-06PHP設(shè)計模式之解釋器(Interpreter)模式入門與應(yīng)用詳解
這篇文章主要介紹了PHP設(shè)計模式之解釋器(Interpreter)模式,結(jié)合實例形式詳細(xì)分析了PHP解釋器模式的概念、原理、基本應(yīng)用與相關(guān)操作注意事項,需要的朋友可以參考下2019-12-12Yii框架中用response保存cookie,用request讀取cookie的原理解析
這篇文章主要介紹了Yii框架中用response保存cookie,用request讀取cookie的原理,結(jié)合實例形式分析了Request.Cookies與Response.Cookies的區(qū)別及相關(guān)使用技巧,需要的朋友可以參考下2019-09-09php float不四舍五入截取浮點型字符串方法總結(jié)
在php中截取浮點型大致有以下幾種方法。需要的朋友可以過來參考下,希望對大家有所幫助2013-10-10