Java实现递归计算n的阶乘

作者:这个对数不太对 时间:2021-06-26 14:34:26 

本文实例为大家分享了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的阶乘

来源:https://blog.csdn.net/m0_57060319/article/details/119616802

标签:java,递归,阶乘
0
投稿

猜你喜欢

  • Java使用CountDownLatch实现网络同步请求的示例代码

    2022-04-23 18:40:52
  • springboot后端配置多个数据源、Mysql数据库的便捷方法

    2022-05-01 07:21:37
  • C#波形图控件制作示例程序

    2022-02-24 21:50:40
  • SpringBoot配置mybatis驼峰命名规则自动转换的实现

    2023-07-26 17:47:43
  • 使用java编程从0到1实现一个简单计算器

    2023-12-06 04:47:53
  • ListView 分页加载更新实例分享

    2021-09-05 06:53:11
  • Android巧用DecorView实现对话框功能

    2022-07-14 14:03:40
  • Java递归实现迷宫游戏

    2023-08-26 07:33:16
  • Java实现邮件找回密码功能

    2022-08-18 07:12:57
  • 浅谈hibernate急迫加载问题(多重外键关联)

    2023-08-18 12:58:54
  • MyBatis动态SQL标签的用法详解

    2021-07-24 10:38:56
  • android Matrix实现图片随意放大缩小或拖动

    2022-02-12 12:06:48
  • kafka的消息存储机制和原理分析

    2022-02-01 13:07:39
  • Spring Bean的线程安全问题

    2023-06-07 17:15:36
  • C#中的==运算符

    2022-08-19 21:50:56
  • Java实现双向循环链表

    2023-11-08 04:14:40
  • C#使用iTextSharp添加PDF水印

    2021-10-09 08:59:27
  • Java 数据结构与算法系列精讲之二叉堆

    2022-05-14 06:31:15
  • mybatis if test判断BigDecimal遇到的坑及解决

    2022-12-06 09:44:24
  • Spring Security和Shiro的相同点与不同点整理

    2023-01-15 17:07:20
  • asp之家 软件编程 m.aspxhome.com