欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java實(shí)現(xiàn)遞歸計(jì)算n的階乘

 更新時(shí)間:2021年08月27日 13:39:02   作者:這個(gè)對(duì)數(shù)不太對(duì)  
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)遞歸計(jì)算n的階乘,利用遞歸的思想實(shí)現(xiàn)階乘的計(jì)算,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了Java實(shí)現(xiàn)遞歸計(jì)算n的階乘的具體代碼,供大家參考,具體內(nèi)容如下

問(wèn)題描述

利用遞歸的思想實(shí)現(xiàn)階乘的計(jì)算,以 n!為例

(一)、n的范圍

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

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

(二)、問(wèn)題分析

1.n<0時(shí)提醒用戶輸入有誤

(1)在未知循環(huán)次數(shù)時(shí),可以采用while語(yǔ)句來(lái)提醒
(2)while語(yǔ)句中用continue結(jié)束循環(huán)

while語(yǔ)句中break和continue的區(qū)別

(1)break:跳出本層循環(huán),即進(jìn)入了一次循環(huán)體后,執(zhí)行完一次循環(huán)體內(nèi)的語(yǔ)句,就不再進(jìn)行是否進(jìn)入循環(huán)體的判斷
(2)continue:跳出本次循環(huán),即進(jìn)入一次循環(huán)體后,執(zhí)行完一次循環(huán)體內(nèi)的語(yǔ)句,會(huì)再次回到循環(huán)入口判斷是否進(jìn)行循環(huán),是則繼續(xù),如此反復(fù)

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

public static void main(String[] args) {
        int n;
        Scanner sc = new Scanner(System.in);
        System.out.println("請(qǐng)輸入n的值");
        n = sc.nextInt();

        while(n<0) {

            System.out.println("輸入有誤,n要大于等于0哦");
            System.out.println("請(qǐng)?jiān)俅屋斎?);
            n = sc.nextInt();
            continue;

        }


    }

2.n>=0時(shí)調(diào)用方法進(jìn)行計(jì)算

(1)新建一個(gè)類構(gòu)造一個(gè)帶參方法 recursion 計(jì)算階乘,注意該方法的名字不能與最初建的類(public class Recursion)重名
(2)引用一個(gè)if語(yǔ)句:當(dāng)n=0或1時(shí),結(jié)果返回為1;其余情況n!=n(n-1)!
(3)階乘的思想是遞歸,即自己調(diào)用自己。不斷地把最新的n用 n * recursion1(n-1) 代替,直到n=1,以此達(dá)到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)由于方法常常封裝在另一個(gè)類里面,所以一般先實(shí)例化一個(gè)對(duì)象(recursion1),再用該對(duì)象調(diào)用該方法(recursion)
(2)實(shí)例化的對(duì)象應(yīng)該是最初類(Recursion)的對(duì)象,所以是Recursion recursion1= new Recursion();
(3)由于類中只能定義變量和方法,不能直接實(shí)例化對(duì)象,也不能寫單獨(dú)的語(yǔ)句,而且在編寫類方法的時(shí)候,不能調(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("請(qǐng)輸入n的值");
        n = sc.nextInt();

        while(n<0) {

            System.out.println("輸入有誤,n要大于等于0哦");
            System.out.println("請(qǐng)?jiān)俅屋斎?);
            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);
        }
    }
}

(四)、運(yùn)行結(jié)果

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java基于面向?qū)ο髮?shí)現(xiàn)一個(gè)戰(zhàn)士小游戲

    Java基于面向?qū)ο髮?shí)現(xiàn)一個(gè)戰(zhàn)士小游戲

    這篇文章主要為大家詳細(xì)介紹了Java如何基于面向?qū)ο髮?shí)現(xiàn)一個(gè)戰(zhàn)士小游戲,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以動(dòng)手嘗試一下
    2022-07-07
  • java11新特性之集合轉(zhuǎn)換為數(shù)組的方法

    java11新特性之集合轉(zhuǎn)換為數(shù)組的方法

    Java11引入了一種將帶有泛型的集合轉(zhuǎn)換為帶有泛型的數(shù)組的簡(jiǎn)單方法,本文通過(guò)實(shí)例代碼介紹java11新特性之集合轉(zhuǎn)換為數(shù)組的操作方法,感興趣的朋友跟隨小編一起看看吧
    2024-06-06
  • Java-Java5.0注解全面解讀

    Java-Java5.0注解全面解讀

    這篇文章主要介紹了Java-Java5.0注解全面解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • springboot 整合 seata的配置過(guò)程

    springboot 整合 seata的配置過(guò)程

    本文給大家介紹springboot 整合 seata的配置過(guò)程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2021-08-08
  • 你了解Java中的Object類嗎

    你了解Java中的Object類嗎

    Object類是所有Java類的祖先。每個(gè)類都使用 Object 作為超類。所有對(duì)象(包括數(shù)組)都實(shí)現(xiàn)這個(gè)類的方法??梢允褂妙愋蜑镺bject的變量指向任意類型的對(duì)象,跟著小編來(lái)具體了解吧
    2021-09-09
  • Java多線程+鎖機(jī)制實(shí)現(xiàn)簡(jiǎn)單模擬搶票的項(xiàng)目實(shí)踐

    Java多線程+鎖機(jī)制實(shí)現(xiàn)簡(jiǎn)單模擬搶票的項(xiàng)目實(shí)踐

    鎖是一種同步機(jī)制,用于控制對(duì)共享資源的訪問(wèn),在線程獲取到鎖對(duì)象后,可以執(zhí)行搶票操作,本文主要介紹了Java多線程+鎖機(jī)制實(shí)現(xiàn)簡(jiǎn)單模擬搶票的項(xiàng)目實(shí)踐,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-02-02
  • SpringBoot使用Minio進(jìn)行文件存儲(chǔ)的實(shí)現(xiàn)

    SpringBoot使用Minio進(jìn)行文件存儲(chǔ)的實(shí)現(xiàn)

    本文主要介紹了SpringBoot使用Minio進(jìn)行文件存儲(chǔ)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • IDEA @SpringBootApplication報(bào)錯(cuò)原因及解決

    IDEA @SpringBootApplication報(bào)錯(cuò)原因及解決

    這篇文章主要介紹了IDEA @SpringBootApplication報(bào)錯(cuò)原因及解決方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 史上最全面的Spring Boot配置文件深入講解

    史上最全面的Spring Boot配置文件深入講解

    Springboot極大的簡(jiǎn)化了Spring框架的使用配置流程,在核心配置文件里,幾乎可以完成所有的配置工作,下面這篇文章主要給大家介紹了關(guān)于Spring Boot配置文件的相關(guān)資料,文中介紹的非常全面,需要的朋友可以參考下
    2018-12-12
  • Mybatis的mapper標(biāo)簽 namespace屬性用法說(shuō)明

    Mybatis的mapper標(biāo)簽 namespace屬性用法說(shuō)明

    這篇文章主要介紹了Mybatis的mapper標(biāo)簽 namespace屬性用法說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09

最新評(píng)論