给你个求阶乘的小程序,只要最大结果位数不超过20000就行。这种超大规模的阶乘是不能用简单的long保存的。位数太大了。
#define M 20000 /* 最大结果位数,DOS能访问的内存有限,最好不要超过 30000 位*/
#define N (M+5)
main()
{
int Num;
register int i,j,k,flag;
register unsigned int n,m,pc;
unsigned char str_n[5],result_0[N],result_1[N];
void fun_print_result(char *result,int flag);
int fun_mul(char *a,char *b,char *c,int flag);
printf("输入计算其阶乘的数:Num = ");
scanf("%d",&Num);
if(Num >= 100)
{
printf("\n正在进行阶乘运算. . .\n");
printf("已完成 00000 的阶乘,请等待. . .");
}
for (j=0;j
{
result_1[j] = 0; resu