服务器之家:专注于服务器技术及软件下载分享
分类导航

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