求大数40000阶乘

来源:互联网 发布:产品经理必备的软件 编辑:程序博客网 时间:2024/05/11 22:23

近来在看算法导论,编译原理方面的书籍,想起写些小玩意就当休闲了,以下是截图

 

C

 

代码如下:

  1. #include <stdio.h>
  2. #include <malloc.h>
  3. #include <time.h>
  4. void main(void)
  5. {
  6.     
  7.     int* Data = malloc(50000*sizeof(int));  //大数的阶乘位数数组如果用数组来存已超过1M堆栈的空间,所以这里用动态存储,预计计算结果不超过100000个数据元素,一个数据元素中最大存储值不大于46340,即最终最大的阶乘值最多可以达到231700000位(天文数字)
  8.     int Digit;  //数据位数变量
  9.     int i,j,r,k;    //循环计数器变量
  10.     int N;  //用户输入要求阶乘的值
  11.     time_t starttime;
  12.     time_t endtime;
  13.     time_t elapsetime;
  14.     
  15.     for (i = 1; i < 50000+1; i++)
  16.     {
  17.         Data[i] = 0;
  18.     }
  19.     Data[0] = 1;    //0位为标志位1
  20.     Data[1] = 1;    //1位为标志位1
  21.     Digit = 1;  //数据位为1,代表大数组中已有几个数组元素作为数据位了
  22.     printf("Enter a number what you want to calculus : ");
  23.     scanf("%d", &N);    //读取欲求N值
  24.     time(&starttime);   //time start
  25.     for (i = 1; i < N+1; i++)
  26.     {
  27.         for (j = 1; j < Digit+1; j++)
  28.         {
  29.             Data[j] *= i;   //数组元素中已有位(数据位)的内容运算
  30.         }
  31.         //转换为46340进制
  32.         for (j = 1; j < Digit+1; j++)
  33.         {
  34.             if (Data[j] > 46340)    //每一位达到46340时,就考虑进位问题(即46340进制),因为在x86 32位os中int型的最大正值是2的31次方减一即2147483647,考虑到最大一个数据位乘46340以上时将超过int的最大范围(这里也说明可以求最大46340左右的数的阶乘),在这一块上可以进行优化(这里一个元素存储46340是否为了尽量使用一个int型所能存储的信息量,即节约了空间),例如修改成long型元素。
  35.             {
  36.                 for (r = j; r < Digit+1; r++)
  37.                 {
  38.                     if (Data[Digit] > 46340)    //动态增加一位,因为可能遇到最高位数据位是46339的情况,最多最高位位数计数器加一
  39.                     {
  40.                         Digit++;    
  41.                     }
  42.                     Data[r+1] += Data[r]/46340; //进位
  43.                     Data[r] = Data[r]%46340;    //留余
  44.                 }
  45.             }
  46.         }
  47.     }
  48.     printf("%d! = ", N);
  49.     for (k = Digit; k > 0; k--)
  50.     {
  51.         printf("%d", Data[k]);
  52.     }
  53.     printf("/n");
  54.     time(&endtime); //time end
  55.     printf("start time : %d/n", starttime);
  56.     printf("end time : %d/n", endtime);
  57.     elapsetime = endtime - starttime;
  58.     printf("elapsetime : %d/n", elapsetime);
  59. }

大数阶乘,大进制,数组,分治策略。思路可以借鉴到其他大数预算操作上。

 

http://blog.csdn.net/jrckkyy
http://hi.baidu.com/jrckkyy

jrckkyy@gmail.com