天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

關(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ù)有點(diǎn)問題,在執(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)累加的方法。而這里如要用遞歸的方法,必須考慮兩點(diǎ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技術(shù)關(guān)于PHP遞歸算法和應(yīng)用方法介紹,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: old老男人野外树林tv | 免费三级网址 | 亚洲AV蜜桃永久无码精品无码网 | sao虎影院桃红视频在线观看 | 日韩欧美高清一区 | 国产色综合色产在线视频 | 日本高清不卡一区久久精品 | 日本孕妇大胆孕交 | 俄罗斯雏妓的BBB孩交 | 亚洲免费人成 久久 | 久久不射视频 | 国产又湿又黄又硬又刺激视频 | 国产AV一区二区三区传媒 | 超碰视频97av | 亚洲欧洲日产国产 最新 | 在线 中文字幕 | 自拍视频亚洲综合在线精品 | 久99久热只有精品国产99 | 99久久伊人一区二区yy5099 | xxxxx俄罗斯| 草民电影网午夜伦理电影网 | 欧美男同gay粗大又长 | 国产午夜精品福利久久 | 高傲教师麻麻被同学调教123 | 竹菊精品久久久久久久99蜜桃 | 天天日免费观看视频一1 | 各种场合肉H校园1V1 | 亚洲无遮挡无码A片在线 | 午夜亚洲动漫精品AV网站 | 国产午夜精品美女免费大片 | 人人干人人看 | 999精品影视在线观看 | 国色天香视频在线社区 | 国产精品一区二区欧美视频 | 秋霞电影网午夜免费鲁丝片 | 久青草国产在线视频亚瑟影视 | 日韩做A爰片久久毛片A片毛茸茸 | 青青草伊人网 | 同居了嫂子在线观看 | 和尚轮流澡到高潮H | 国产在线观看免费 |