求大数40000阶乘

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

 

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Zda天天爱打卡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值