先考虑一下思路
即使用递归的方法来实现这个函数的使用。
即实现代码:
public class TestMul{
public static void main(String[] args) {
System.out.println(fac(60));
}
public static double fac(int num){ //此处需注意60的阶乘会是一个很大的数,一般返回类型会溢出,这里采用了double类型
if(num == 1){
return 1;
}else{
return num*fac(num-1);
}
}
}
在JAVA中有两个类BigInteger和BigDecimal分别表示大整数类和大浮点数类两个大数据类都是无限精度的,用法请查看JDK_API。
所以我们还可以调用包。
import java.math.BigInteger;
public class TestMul{
public static void main(String[] args) {
Integer a = 60;
BigInteger s =fac(new BigInteger(a.toString()));
System.out.println(s);
System.out.println(s.toString());
System.out.println(s.toString().length());
}
public static BigInteger fac(BigInteger num){
BigInteger s = BigInteger.ZERO ;
if (num.compareTo(BigInteger.ONE) == 0){
s= BigInteger.ONE;
}else {
s = num.multiply(fac(num.subtract(BigInteger.ONE)));
}
return s;
}
}