问题描述:求一个整数 n 的阶乘,0 <= n <=5000。
比如n = 50,结果为30414093201713378043612608166064768844377641568960512000000000000
思路:从阶乘的定义出发,n! = n * (n-1) * (n-2) * ... * 2 * 1。由于 n 很大,基本的数据类型是无法存储的。不过,我们可以用一个整型数组来存放结果(包括中间结果),数组的每一个元素存放结果的一位,数组的第一个元素初始化为1。计算过程比较简单,将n, n-1, n-2, 1依次乘以当前值,也