Java實現(xiàn)遞歸計算n的階乘
本文實例為大家分享了Java實現(xiàn)遞歸計算n的階乘的具體代碼,供大家參考,具體內(nèi)容如下
問題描述
利用遞歸的思想實現(xiàn)階乘的計算,以 n!為例
(一)、n的范圍
1.n<0:n!無意義
2.n=0或n=1:n!=1
3.n>2:n!=n(n-1)!
關(guān)于 0!=1 的一個合理性解釋:
根據(jù)階乘的定義n!=n(n-1)!,
可變形為n=(n+1)!/(n+1),
帶入有0=1!/1=1
(二)、問題分析
1.n<0時提醒用戶輸入有誤
(1)在未知循環(huán)次數(shù)時,可以采用while語句來提醒
(2)while語句中用continue結(jié)束循環(huán)
while語句中break和continue的區(qū)別
(1)break:跳出本層循環(huán),即進入了一次循環(huán)體后,執(zhí)行完一次循環(huán)體內(nèi)的語句,就不再進行是否進入循環(huán)體的判斷
(2)continue:跳出本次循環(huán),即進入一次循環(huán)體后,執(zhí)行完一次循環(huán)體內(nèi)的語句,會再次回到循環(huán)入口判斷是否進行循環(huán),是則繼續(xù),如此反復(fù)
由于不能確定用戶輸入有誤的次數(shù),所以要用continue
public static void main(String[] args) {
int n;
Scanner sc = new Scanner(System.in);
System.out.println("請輸入n的值");
n = sc.nextInt();
while(n<0) {
System.out.println("輸入有誤,n要大于等于0哦");
System.out.println("請再次輸入");
n = sc.nextInt();
continue;
}
}
2.n>=0時調(diào)用方法進行計算
(1)新建一個類構(gòu)造一個帶參方法 recursion 計算階乘,注意該方法的名字不能與最初建的類(public class Recursion)重名
(2)引用一個if語句:當(dāng)n=0或1時,結(jié)果返回為1;其余情況n!=n(n-1)!
(3)階乘的思想是遞歸,即自己調(diào)用自己。不斷地把最新的n用 n * recursion1(n-1) 代替,直到n=1,以此達到n!=n(n-1)(n-2)···2·1的結(jié)果
public static int recursion (int n) {
if (n==0||n==1)
return 1;
else{
return n * recursion(n-1);
}
}
3.結(jié)果輸出放在main()中
(1)由于方法常常封裝在另一個類里面,所以一般先實例化一個對象(recursion1),再用該對象調(diào)用該方法(recursion)
(2)實例化的對象應(yīng)該是最初類(Recursion)的對象,所以是Recursion recursion1= new Recursion();
(3)由于類中只能定義變量和方法,不能直接實例化對象,也不能寫單獨的語句,而且在編寫類方法的時候,不能調(diào)用類本身(除非編寫的是類中的main方法),所以這兩行代碼應(yīng)該放在main()方法中。
Recursion recursion1= new Recursion();
System.out.println("n!="+ recursion1.recursion(n));
(三)、完整代碼
把以上代碼合并一下
import java.util.*;
public class Recursion {
public static void main(String[] args) {
int n;
Scanner sc = new Scanner(System.in);
System.out.println("請輸入n的值");
n = sc.nextInt();
while(n<0) {
System.out.println("輸入有誤,n要大于等于0哦");
System.out.println("請再次輸入");
n = sc.nextInt();
continue;
}
Recursion recursion1= new Recursion();
System.out.println("n!="+ recursion1.recursion(n));
}
public static int recursion (int n) {
if (n==0||n==1)
return 1;
else{
return n * recursion(n-1);
}
}
}
(四)、運行結(jié)果

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
解決spring boot網(wǎng)關(guān)gateway導(dǎo)致的坑,無法下載文件問題
這篇文章主要介紹了解決spring boot網(wǎng)關(guān)gateway導(dǎo)致的坑,無法下載文件的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07
SpringBoot如何優(yōu)雅的實現(xiàn)重試功能
這篇文章主要詳細(xì)介紹了SpringBoot如何優(yōu)雅的實現(xiàn)重試功能的步驟詳解,文中有詳細(xì)的代碼示例,具有一定的參考價值,感興趣的同學(xué)可以借鑒閱讀2023-06-06
使用Mybatis-plus策略自動更新數(shù)據(jù)庫時間失敗問題解決
這篇文章主要介紹了使用Mybatis-plus策略自動更新數(shù)據(jù)庫時間失敗問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10
Transactional注解導(dǎo)致Spring Bean定時任務(wù)失效的解決方法
這篇文章主要介紹了Transactional注解導(dǎo)致Spring Bean定時任務(wù)失效的解決方法,文中通過代碼示例介紹的非常詳細(xì),對大家解決問題有一定的幫助,需要的朋友可以參考下2024-10-10
使用SpringBoot的CommandLineRunner遇到的坑及解決
這篇文章主要介紹了使用SpringBoot的CommandLineRunner遇到的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-02-02
java實現(xiàn)emqx設(shè)備上下線監(jiān)聽詳解
這篇文章主要為大家介紹了java實現(xiàn)emqx設(shè)備上下線監(jiān)聽詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07

