[笔试面试题]求大数的阶乘(如1024的阶乘)

   对于大数的阶乘,毫无疑问,需要借助其他的数据结构来进行辅助存储。比如可用字符串或者整形数组来辅助存储。

而我们需要的就是设计一个简单的乘法器就行了,下面是用数组存储来实现的。

 

#include <iostream>
using namespace std;

int bigArray[20000]; //用来存储结果的数组

int bigFactorial(int n)
{
 int tag = 0;  //进位标志
 int digit = 1;  //位数
 int temp;   //临时结果
 bigArray[0] = 1; //初始化第一位为1

 for(int i = 2;i < n;i++)
 {
  for(int j = 1;j <= digit;++j)
  {
   temp = bigArray[j - 1] * i + tag;
   bigArray[j - 1] = temp % 10;
   tag = temp / 10;
  }

  while(tag)
  {
   bigArray[(++digit) - 1] = tag % 10;
   tag = tag / 10;
  }
 }
 
 return digit;
}

int main()
{
 int length = bigFactorial(1024);

 for(int j = length - 1;j >= 0; j--)
 {
  cout<<bigArray[j];
 }

 cout<<endl;
 return 0;
}

 

----------------------

    用数组来存放的话,有个很大的问题就是无法确定位数,所以有时会很浪费空间。其实我们还可以用String来存储,

然后在使用时对于char用‘’-‘0’或者atoi函数的方式转成整数再计算。这里不再讨论。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值