gpt4 book ai didi

java - 选择哪种数据类型或数据结构来计算 100 的阶乘?

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:42:49 29 4
gpt4 key购买 nike

我想写一个程序来评估给定整数的阶乘。

根据基础知识,我用 java 编写了以下代码:

long fact(int num){
if(num == 1)
return 1;
else
return num*fact(num-1);
}

但后来我意识到,对于许多整数输入,结果可能不是期望的结果,因此为了测试直接给输入 100。

我的怀疑是真的,因为我得到的结果是“0”(因为结果可能超出了 long 的范围)。

所以,我只是很好奇,也很想知道如何让我的程序处理输入 <=150。

如果有任何有效的 C 编程语言或 Java 解决方案,我将不胜感激。

最佳答案

BigInteger 是您的类(class)。它可以存储看似任何大小整数

    static BigInteger fact(BigInteger num) {
if (num.equals(BigInteger.ONE))
return BigInteger.ONE;
else
return num.multiply(fact(num.subtract(BigInteger.ONE)));
}

关于java - 选择哪种数据类型或数据结构来计算 100 的阶乘?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15205587/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com