阶乘:一个非负整数n的阶乘是所有的正整数小于或等于 n之积。
阶乘亦可以递归方式定义:0!=1,n!=(n-1)!×n。
阶乘是基斯顿·卡曼(Christian Kramp,1760~1826)于 1808 年发明的运算符号,是数学术语。
在计算机相关专业的大学课程《离散数学》会学到阶乘。
在Java中,阶乘也是面试题中较为常见的算法题目。
下面跟着我看看如何使用Java计算阶乘
先上源代码:
public class Main{
final static int MAX=10;// 替换 MAX 的值。
public static void main(String[] args)
{
int i=1;
long result=1;
long[] n=new long[MAX];
System.out.println(i+"!="+result);
do{
result*=(i+1);
System.out.println(i+1+"!="+result);
n[i]=result;
i++;
}while(i
n[0]=1;
}
}
它的运行结果是:
通过替换MAX的值,我们可以更改获得的阶乘数。
从代码我们可以看到,MAX是一个final常量,当这个常量大于20的时候,控制台输出的阶乘值会出现负数,这是因为数据溢出了,这是正常现象,但是也是有一些办法可以阻止溢出,这个问题留给你们思考咯。
?在线客服?