62,634
社区成员




public class J_largeNumber
{
public static void main(String args[])
{
byte n=1,temp;
byte [] result=new byte [30];
byte [] npow1=new byte [30];
byte [] npow2 = new byte [30];
for (byte i=1;n<=20;n++)//计算1至20的阶乘和
{
npow1[0]=(byte)(n%10);
npow1[1]=(byte)(n/10);
while(i<n)//计算1至20的阶乘
{
for(int j=0;j<npow1.length;j++)//计算两个数相乘
{
temp=(byte)(npow1[j]*i);
for(int k=j;0!=temp;k++)//计算每一位相乘
{
npow2[k]+=temp%10;
if (npow2[k]>9)//进位
{
npow2[k+1]++;
npow2[k]-=10;
}
temp/=10;
}
}
for(int j=0;j<npow1.length;j++)//将结果给被乘数
{
npow1[j]=npow2[j];
}
for(int j=0;j<npow2.length;j++)//结果重新赋值为零
{
npow2[j]=0;
}
}
for (int j=0;j<npow1.length;j++)
{
result[j]+=npow1[j];
if (result[j]>9)
{
result[j+1]++;
result[j]-=10;
}
}
}
for(int j=0;j<result.length;j++)
System.out.print(result[j]);
}
}
import java.math.BigDecimal;
public class Factorial {
public static void main(String[] args) {
BigDecimal result = new BigDecimal(1);
for (int i = 1; i < 501; i++) {
BigDecimal value = new BigDecimal(i);
result = result.multiply(value);
}
System.out.println("result = " + result);
}
}