中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP遞歸函數算法和應用

發布時間:2021-09-04 00:20:07 來源:億速云 閱讀:160 作者:chen 欄目:編程語言

這篇文章主要介紹“PHP遞歸函數算法和應用”,在日常操作中,相信很多人在PHP遞歸函數算法和應用問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”PHP遞歸函數算法和應用”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

1、調用子程序的含義:

當主程序執行到調用子程序A語句時,系統保存一些必要的現場數據,然后執行類似于BASIC語言的GOTO語句,跳轉到子程序A(為了說得簡單些,我這里忽略了參數傳遞這個過程)。當子程序A執行到調用子程序B語句時,系統作法如上,跳轉到子程序B。子程序B執行完所有語句后,跳轉回子程序A調用子程序B語句的下一條語句(我這又忽略了返回值處理)子程序A執行完后,跳轉回主程序調用子程序A語句的下一條語句,主程序執行到結束。做個比較:我在吃飯(執行主程序)吃到一半時,某人叫我(執行子程序A),話正說到一半,電話又響了起來(執行子程序B),我只要先接完電話,再和某人把話說完,***把飯吃完(我這飯吃得也夠累的了J)。

2、認識遞歸函數

我們在高中時都學過數學歸納法,PHP遞歸算法例如:

求 n!我們可以把n!這么定義也就是說要求3!,我們必須先求出2!,要求2!,必須先求1!,要求1!,就必須先求0!,而0!=1,所以1!=0!*1=1,再進而求2!,3!。分別用函數表示,我們可以觀察到,除計算0!子程序外,其他的子程序基本相似,我們可以設計這么一個子程序:

int factorial(int i){  int res;  res=factorial(I-1)*i;  return res;  }

那么當執行主程序語句s=factorial(3)時,就會執行factorial(3),但在執行factorial(3),又會調用 factorial(2),這時大家要注意,factorial(3)和factorial(2)雖然是同一個代碼段,但在內存中它的數據區是兩份!而執行factorial(2)時又會調用factorial(1),執行factorial(1)時又會調用factorial(0),每調用一次 factorial函數,它就會在內存中新增一個數據區,那么這些復制了多份的函數大家可以把它看成是多個不同名的函數來理解;但我們這個函數有點問題,在執行factorial(0)時,它又會調用factorial(-1)。。。造成死循環,也就是說,在factorial函數中,我們要在適當的時候保證不再調用該函數,也就是不執行res=factorial(I-1)*i;這條調用語句。所以函數要改成:

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本來這個問題我們過去常用循環累加的方法。而這里如要用遞歸的方法,必須考慮兩點:
1) 能否把問題轉化成遞歸形式的描述;
2) 是否有遞歸結束的邊界條件。

顯然遞歸的兩個條件都有了:

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、遞歸的應用

中序遍歷二叉樹

void inorder (BinTree T){  if (T){  inorder(T->lchild);  printf(“%c”,T->data);  inorder(T->rchild);  }  }

到此,關于“PHP遞歸函數算法和應用”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

php
AI

威宁| 蚌埠市| 兴义市| 集贤县| 海安县| 文成县| 龙山县| 获嘉县| 岱山县| 开封县| 新巴尔虎左旗| 神池县| 印江| 新民市| 永昌县| 德保县| 积石山| 东至县| 海原县| 伊金霍洛旗| 武川县| 九江市| 桃江县| 新晃| 广平县| 顺昌县| 原阳县| 南岸区| 会东县| 重庆市| 迭部县| 松潘县| 全州县| 靖安县| 繁昌县| 高阳县| 九龙县| 界首市| 彝良县| 铅山县| 称多县|