java – 选择哪种数据类型或数据结构来计算100的阶乘?
发布时间:2020-05-24 18:53:51 所属栏目:Java 来源:互联网
导读:我想写一个程序来评估给定整数的阶乘. 以下基础知识我在java中编写了以下代码: long fact(int num){if(num == 1) return 1;else return num*fact(num-1);} 但后来我意识到,对于许多整数输入,结果可能不是所期望的,因此对于测试直接给出输入为100. 我怀疑是真
|
我想写一个程序来评估给定整数的阶乘. 以下基础知识我在java中编写了以下代码: long fact(int num){
if(num == 1)
return 1;
else
return num*fact(num-1);
}
但后来我意识到,对于许多整数输入,结果可能不是所期望的,因此对于测试直接给出输入为100. 我怀疑是真的,因为我得到的结果是“0”(原因结果可能超出了长期范围). 所以,我只是好奇并渴望知道如何让我的程序适用于输入< = 150. 我很感激C编程语言或Java中的任何有效解决方案. 解决方法BigInteger是你的班级.它可以存储看似任何大小的整数.static BigInteger fact(BigInteger num) {
if (num.equals(BigInteger.ONE))
return BigInteger.ONE;
else
return num.multiply(fact(num.subtract(BigInteger.ONE)));
} (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
