您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)使用Java怎么編寫一個(gè)遞歸程序,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。
遞歸的定義
遞歸(recursion):以此類推是遞歸的基本思想,將規(guī)模大的問題轉(zhuǎn)化為規(guī)模小的問題來解決。
自定義遞歸函數(shù),并確定函數(shù)的基本功能
例如Java從鍵盤輸入一個(gè)數(shù),求輸入這個(gè)數(shù)的階乘。這個(gè)時(shí)候把輸入的數(shù)字作為形參
int diGuiTest(int n ){ }
找到遞歸函數(shù)循環(huán)結(jié)束條件
在求階乘的時(shí)候,我們不妨做出如下思考,例如輸入的n是5,那么5!是5 * 4 3 * 2 * 1,那是不是可以寫成
n f(n-1)?,程序運(yùn)行過程如下:
5* f(4)
f(4)相當(dāng)于重新調(diào)用了函數(shù),形參為4
5 * 4* f(n-1)
f(3)相當(dāng)于重新調(diào)用了函數(shù),形參為3
5 * 4* 3* f(n-1)
f(2)相當(dāng)于重新調(diào)用了函數(shù),形參為2
5 * 4* 3 * 2* f(n-1)
f(1)相當(dāng)于重新調(diào)用了函數(shù),形參為1
很容易發(fā)現(xiàn),這時(shí)候如果遞歸調(diào)用到n為1的時(shí)候,就要結(jié)束調(diào)用自身
代碼如下:
int diGuiTest(int n ){ if(n==1){ return 1; } else{ return n*f(n-1); } }
求1–100之間所有自然數(shù)的和
int sum (int n ){ if(n==1){ return 1 ; } else{ return n+sum(n-1); } }
斐波拉契數(shù)列
斐波那契數(shù)列(Fibonacci sequence),又稱黃金分割數(shù)列,因數(shù)學(xué)家萊昂納多·斐波那契(Leonardoda Fibonacci)以兔子繁殖為例子而引入,故又稱為“兔子數(shù)列”,指的是這樣一個(gè)數(shù)列:0、1、1、2、3、5、8、13、21、34、……在數(shù)學(xué)上,斐波那契數(shù)列以如下被以遞推的方法定義:F(0)=0,F(xiàn)(1)=1, F(n)=F(n - 1)+F(n - 2) (n ≥ 2,n ∈ N*)
int fibonacci(int n ){ if (n<=1){ return n; } else { return fibonacci(n-1)+fibonacci(n-2); } }
漢諾塔問題
首先我們考慮最簡(jiǎn)單的情況:
將最上面的一塊放到B,再將最下面一塊放到C,再把最上面一塊從B放到C即可
public class Hanio { public static void main(String[] args) { char A='A'; char B='B'; char C='C'; hannio(3,A,B,C); } static void hannio(int paltfrom,char A,char B, char C){ if (paltfrom==1){ move (A,C); }else { hannio(paltfrom-1,A,C,B);//上面兩個(gè)盤子,通過C柱到B柱 move (A,C); hannio(paltfrom-1,B,A,C);// } } static void move(char A,char B){ System.out.println(A+"---->"+B); } }
關(guān)于使用Java怎么編寫一個(gè)遞歸程序就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。