一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java實現遞歸計算n的階乘

Java實現遞歸計算n的階乘

2021-12-07 13:59這個對數不太對 Java教程

這篇文章主要為大家詳細介紹了Java實現遞歸計算n的階乘,利用遞歸的思想實現階乘的計算,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了Java實現遞歸計算n的階乘的具體代碼,供大家參考,具體內容如下

問題描述

利用遞歸的思想實現階乘的計算,以 n!為例

(一)、n的范圍

1.n<0:n!無意義
2.n=0或n=1:n!=1
3.n>2:n!=n(n-1)!

關于 0!=1 的一個合理性解釋:
根據階乘的定義n!=n(n-1)!,
可變形為n=(n+1)!/(n+1),
帶入有0=1!/1=1

(二)、問題分析

1.n<0時提醒用戶輸入有誤

(1)在未知循環次數時,可以采用while語句來提醒
(2)while語句中用continue結束循環

while語句中break和continue的區別

(1)break:跳出本層循環,即進入了一次循環體后,執行完一次循環體內的語句,就不再進行是否進入循環體的判斷
(2)continue:跳出本次循環,即進入一次循環體后,執行完一次循環體內的語句,會再次回到循環入口判斷是否進行循環,是則繼續,如此反復

由于不能確定用戶輸入有誤的次數,所以要用continue

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
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時調用方法進行計算

(1)新建一個類構造一個帶參方法 recursion 計算階乘,注意該方法的名字不能與最初建的類(public class Recursion)重名
(2)引用一個if語句:當n=0或1時,結果返回為1;其余情況n!=n(n-1)!
(3)階乘的思想是遞歸,即自己調用自己。不斷地把最新的n用 n * recursion1(n-1) 代替,直到n=1,以此達到n!=n(n-1)(n-2)···2·1的結果

?
1
2
3
4
5
6
7
8
public static int recursion (int n) {
 
        if (n==0||n==1)
            return 1;
        else{
            return n * recursion(n-1);
        }
    }

3.結果輸出放在main()中

(1)由于方法常常封裝在另一個類里面,所以一般先實例化一個對象(recursion1),再用該對象調用該方法(recursion)
(2)實例化的對象應該是最初類(Recursion)的對象,所以是Recursion recursion1= new Recursion();
(3)由于類中只能定義變量和方法,不能直接實例化對象,也不能寫單獨的語句,而且在編寫類方法的時候,不能調用類本身(除非編寫的是類中的main方法),所以這兩行代碼應該放在main()方法中。

?
1
2
Recursion recursion1= new Recursion();
    System.out.println("n!="+ recursion1.recursion(n));

(三)、完整代碼

把以上代碼合并一下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
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);
        }
    }
}

(四)、運行結果

Java實現遞歸計算n的階乘

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/m0_57060319/article/details/119616802

延伸 · 閱讀

精彩推薦
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7482021-02-04
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
主站蜘蛛池模板: 国产亚洲精品九九久在线观看 | 国产欧美精品一区二区三区–老狼 | 忘忧草在线社区WWW日本-韩国 | 日韩国产欧美视频 | 女医学护士一级毛片 | 久久伊人影视 | 亚洲视频男人的天堂 | sedog在线长片| xx18美女美国 | 国产一区二区免费不卡在线播放 | 1769在线视频 | 垫底辣妹免费观看完整版 | 国产亚洲精品看片在线观看 | 亚洲视频中文 | 天堂a免费视频在线观看 | 特级非洲黑人一级毛片 | 天堂资源在线8 | 欧美日韩精品一区二区三区视频 | 手机看片自拍自自拍日韩免费 | 无删减影视免费观看 | 免费在线中文字幕 | 欧美大片一区二区 | 亚洲天堂色图 | www.av色| 午夜私人影院在线观看 | 黑人疯狂巨大xxoo | 免费a漫 - 禁密天堂 | 欧美最猛性xxxxx短视频 | 久久视频这只精品99re6 | 午夜理论片YY4399影院 | 亚偷熟乱区视频在线观看 | 国产一区日韩二区欧美三 | 脱了白丝校花的内裤猛烈进入 | 免费观看欧美性一级 | zoomkool最新版 | 亚洲上最大成网人站4438 | 亚洲 欧美 国产 综合首页 | 国产无限免费观看黄网站 | 欧美日韩一区不卡 | 青青网在线视频 | 午夜影院网页 |