91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

Java怎么實現遞歸計算n的階乘

發布時間:2021-08-27 17:11:00 來源:億速云 閱讀:427 作者:chen 欄目:開發技術

本篇內容主要講解“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

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的結果

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()方法中。

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);
        }
    }
}

(四)、運行結果

Java怎么實現遞歸計算n的階乘

到此,相信大家對“Java怎么實現遞歸計算n的階乘”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

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

AI

大庆市| 凌源市| 巴林左旗| 南阳市| 鸡泽县| 垣曲县| 手机| 三穗县| 定西市| 合水县| 榆林市| 乳山市| 景谷| 新竹市| 滨州市| 和田县| 吉安县| 和政县| 宣化县| 桐梓县| 抚远县| 门源| 海林市| 渑池县| 淮南市| 晋宁县| 台州市| 凭祥市| 临高县| 灌阳县| 普宁市| 桓台县| 顺平县| 元谋县| 怀宁县| 仁布县| 永和县| 城口县| 万盛区| 河北区| 博兴县|