过多的我就不说了,直接看看代码:
java版的:
/** * */ package Factorial; /** * @author 牟尼(昵称) * @blog:http://blog.csdn.net/u012027907 * */ public class Factorial { /* * 大数阶乘计算类 */ /* * 分析:大数阶乘用数组来存储,如5的阶乘可存在数组cal[]中,表示为 * 0 1 2 3 *[3][0][2][7] *个位存阶乘的位数 *要求5的阶乘,则要求得4!的结果,一直要求的1!的结果为1; *所以使用循环即可 */ /* * 大数阶乘计算 */ public String fac(int num){ String result; //最终结果的字符串 int max; //阶乘的位数 double sum = 0; for(int i = 2; i <=num; i++){//计算阶乘的位数 sum += Math.log10(i); } max = (int)sum +1; int cal[] = new int[max+1];//开辟空间 for(int j = 1; j <= max; j++) cal[j] = 0; cal[0] = max; //cal[0]存储阶乘的位数 cal[1] = 1; int g = 0;//进位 for(int k = 2; k <= num; k++){//从2乘到num g = 0; for(int i =1; i <=max;i++){//计算每个k与数组相乘的结果 cal[i] = cal[i]*k + g; g = cal[i]/10; cal[i] = cal[i]%10; } } result = ""; for(int i = max; i > 0; i--)//将整型数组转为字符串 result += cal[i]; return result; } }运行结果:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。