标题:大数的阶乘
取消只看楼主
yyll
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2009-9-7
结帖率:0
 问题点数:0 回复次数:2 
大数的阶乘
#include <stdio.h>
void main()
{
    int a[50],i,j,m,k;
    printf("input a num:\n");
    scanf("%d",&m);
    a[0]=1;
    for(i=1;i<50;i++)
      a[i]=0;
    for (i=1;i<=m;i++)
      {
          for (j=0;j<50;j++)
          a[j]=a[j]*i;
          for (j=0;j<50;j++)
           {
            if(a[j]>=10&&a[j]<100)
             {
               a[j+1]=a[j+1]+a[j]/10;
               a[j]=a[j]%10;
               
                      }
           if(a[j]>=100)
           {
             a[j+1]=a[j+1]+a[j]/10;
             a[j]=a[j]%100;
            
            }
           }
              }
          for(i=49;i>=0;i--)
          if(a[i]==0) continue  ;
          else break;
              printf("i=%d\n",i+1);
          printf("%d!=",m);
          for(k=i;k>=0;k--)
           printf("%d",a[k]);
           putchar('\n');
              getch();
        }




                       
                       
搜索更多相关主题的帖子: 阶乘 大数 
2009-10-28 22:41
yyll
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2009-9-7
得分:0 
这是用数组记录每个位!数组大小可以改变!
2009-11-16 12:00
yyll
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2009-9-7
得分:0 
回复 3楼 m456m654
那个数组时用来结果位数的,最大50位,这个数值还能改!这仅代表一种处理方法。
2009-11-18 00:31



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-290301-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.580969 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved