使用递归计算阶乘,并输出结果末尾有几位零

使用递归计算阶乘,并输出结果末尾有几位零

package CH12_Expand.XZ01;

import java.util.Scanner;

public class Factorial {
    public static void main(String[] args) {

//         100的阶乘的末尾有多少个0? 例如N=10,N的阶乘=3628800,末尾有两个0
//         一个数 N 的阶乘末尾有多少个 0 取决于从 1 到 n 的各个数的因子中 2 和 5 的个数, 而 2 的个数是远远多余 5 的个数的
//         因此求出 5 的个数即可. 题解中给出的求解因子 5 的个数的方法是用 n 不断除以 5, 直到结果为 0, 然后把中间得到的结果累加
//         例如, 100/5 = 20, 20/5 = 4, 4/5 = 0, 则 1 到 100 中因子 5 的个数为 (20 + 4 + 0) = 24 个
//         即 100 的阶乘末尾有 24 个 0. 其实不断除以 5, 是因为每间隔 5 个数有一个数可以被 5 整除
//         然后在这些可被 5 整除的数中, 每间隔 5 个数又有一个可以被 25 整除, 故要再除一次, ... 直到结果为 0, 表示没有能继续被 5 整除的数了
        Scanner input = new Scanner(System.in);
        System.out.print("输入需要阶乘的数字(输出阶乘结果后有几个零:)");
        int num = input.nextInt();
        // 自定义变量  num 接收需要阶乘的变量
        System.out.println("利用递归计算" + num + "的阶乘为" + recursion(num));
        //调用 recursion 方法 计算  num 阶乘结果
        int count = 0;
        // 定义变量存储 阶乘结果有几个零
        for (int i = 0; i < num; i++) {
            num = num / 5;
            // 求出因字数 5 的个数
            count = count + num;
            // 将因字数相加
        }
        System.out.println(count);
        // 输出计算结果 n! 中有几个因子5 即为 N! 结果末尾有几个零
    }


    public static int recursion(int num) {
        //利用递归计算阶乘
        int sum = 1;
        if (num < 0) {
            throw new IllegalArgumentException("必须为正整数!");
        }
        //抛出不合理参数异常
        if (num == 1) {
            return 1;
            //根据条件,跳出循环
        } else {
            sum = num * recursion(num - 1);
            //运用递归计算
            return sum;
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值