微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

1.精度计算——大数阶乘

语法:intresult=factorial(int n);

      参数:

      n:n 的阶乘

      返回值:阶乘结果的位数

      注意:

       本程序直接输出n!的结果,需要返回结果请保留long a[]

       需要 math.h

      源程序:

      

 int factorial(int n)
      {
      long a[10000];
      int i,j,l,c,m=0,w;
      a[0]=1;
      for(i=1;i<=n;i++)
          {
          c=0;
          for(j=0;j<=m;j++)
              {
              a[j]=a[j]*i+c;
              c=a[j]/10000;
              a[j]=a[j]%10000;
          }
          if(c>0) {m++;a[m]=c;}
      }
 
      w=m*4+log10(a[m])+1;
      printf("\n%ld",a[m]);
      for(i=m-1;i>=0;i--)printf("%4.4ld",a[i]);
      return w;
      } 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐