杭电ACM—— 1042 N!大数阶乘

本文介绍了一种使用数组模拟乘法实现大数阶乘的算法,解决了整型变量溢出的问题,适用于计算如1000!甚至10000!这样的大数阶乘。

数的阶乘,到13!整型变量就会溢出。而要算到1000!,甚至到10000!就要用字符串的来模拟乘法运算。


下面是代码:

#include <stdio.h>
#include <string.h>
int main()
{
	int n, i, j, end;
	int a[100000] = {0};
	while(scanf("%d", &n) != EOF)
	{
	    memset(a, 0, sizeof(a));
	    end = 0;
		a[0] = 1;
		for(i = 1; i <= n; i++)
		{
		    //模拟乘法运算,每一位都乘以i
			for(j = 0; j <= end; j++)
			{
				a[j] = a[j] * i;
			}
			//进位
			for(j = 0; j <= end; j++)
			{
				if(a[j] > 10000 && j == end)
				{
					int c = a[j] / 10000 ;
					a[j] = a[j] % 10000 ;
                    a[j+1] += c ;
                    end++ ;
				}
				else if(a[j] > 10000)
				{
                    int c = a[j] / 10000 ;
					a[j] = a[j] % 10000 ;
					a[j+1] += c ;
				}

			}
		}
		printf("%d", a[end]);
		for(i = end - 1; i >=0 ; i--)
		{
			printf("%04d",a[i]);
		}
        printf("\n");
	}
	return 0;
}
采用四位一存的方法,效率比一位一存的快。

下面是结果:


模拟的乘法运算:

比如 11 * 12 


这是一位一存的,同理,四位一存就是大于100000就进位~~~

可以自行用笔演算一下,我可能讲的不是很清楚,请见谅!!~~

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值