簡單的java遞迴演算法
- example: 求5的階乘。。
- 如下:
- public class Test {
- static int multiply(int n){
- if(n==1||n==0)
- return n;
- else
- return n*multiply(n-1);
- }
- public static void main(String[] args){
- System.out.println(multiply(10));
- }
- }
- 上面的multiply是一個階乘的例子。其實遞迴遞迴,從字面上解釋就是在方法本身呼叫自己的方法,或者間接呼叫;看上面的程式,拿multiply(5)來說:
- n=5;執行 5*multiply(4);
- --------------------
- 這時候看multiply(4)
- n=4 執行 4*multiply(3);
- -------------------
- 看multiply(3)
- n=3,執行 3*multiply(2);
- ---------------
- mulitply(2);
- n=2 執行 2*mulitply(1);
- 這時候,return 1;往上返回
- 2*1向上返回
- 3*(2*1)向上返回
- 4*(3*(2*1)) 向上返回
- 5*(4*(3*(2*1))) = 120
- 所以程式輸出120;
- 這事簡單的遞迴的例子;所以可以看出來遞迴的關鍵得有遞迴出口(本體的If語句),還有遞迴方法;
相關文章
- 遞迴的簡單應用遞迴
- Java遞迴演算法Java遞迴演算法
- Java遞迴演算法的使用Java遞迴演算法
- JavaScript之遞迴的簡單使用JavaScript遞迴
- 尾遞迴(tail recursion) 的簡單使用遞迴AI
- 30、java中遞迴演算法Java遞迴演算法
- javascript遞迴概念簡單介紹JavaScript遞迴
- 二分法的簡單實現——-遞迴和非遞迴遞迴
- 遞迴演算法轉換為非遞迴演算法的技巧遞迴演算法
- 遞迴 Java遞迴Java
- 解讀:什麼是Java的遞迴演算法?Java遞迴演算法
- 遞迴演算法遞迴演算法
- 二十一、氣泡排序演算法——JAVA實現(遞迴與非遞迴)排序演算法Java遞迴
- Python技法:實現簡單的遞迴下降ParserPython遞迴
- js支援的最大遞迴次數簡單介紹JS遞迴
- 單連結串列逆置遞迴演算法遞迴演算法
- 揹包問題的遞迴與非遞迴演算法遞迴演算法
- 二十、快速排序演算法——JAVA實現(遞迴)排序演算法Java遞迴
- 演算法小專欄:遞迴與尾遞迴演算法遞迴
- 【演算法】遞迴演算法演算法遞迴
- 最長公共子序列,遞迴簡單程式碼遞迴
- 遞迴演算法要素遞迴演算法
- 快速排序(遞迴及非遞迴演算法原始碼)排序遞迴演算法原始碼
- Java演算法面試題(001) 如何使用迴圈和遞迴計算單連結串列的長度Java演算法面試題遞迴
- 遞迴演算法程式設計整數因子分解問題的遞迴演算法遞迴演算法程式設計
- Java中的遞迴原理分析Java遞迴
- 演算法初探--遞迴演算法演算法遞迴
- Python3之遞迴函式簡單示例Python遞迴函式
- 遞迴演算法-不帶頭節點的單連結串列遞迴演算法
- 簡單理解Java中的4種迴圈Java
- Java簡單迴圈語句案例Java
- 淺談遞迴演算法遞迴演算法
- JavaScript演算法之遞迴JavaScript演算法遞迴
- 每日一演算法:遞迴演算法遞迴
- 【Java資料結構與演算法筆記(二)】樹的四種遍歷方式(遞迴&非遞迴)Java資料結構演算法筆記遞迴
- 化繁為簡 經典的漢諾塔遞迴問題 in Java遞迴Java
- 原:八皇后問題的遞迴和非遞迴Java實現遞迴Java
- 簡單快遞系統 java實現Java