码迷,mamicode.com
首页 > 其他好文 > 详细

大数据阶乘——字符串乘法器

时间:2017-05-13 20:58:12      阅读:150      评论:0      收藏:0      [点我收藏+]

标签:存储   最大   大数   int   开始   cal   span   i++   ++   

char s[1001]; //字符串s存储乘法得到的大数字,s[0]代表低位

int GetLength()//返回s的最大不为空的元素下标
{
    int i;
    for(i=1000; i>=0; i--)
    {
        if(s[i]!=0)
        {
            break;
        }
    }
    return i;
}

void cal(int k)//计算大数字s和小数字k相乘
{
    int add=0;//进位数
    int i;
    int temp;
    for(i=0; i<=GetLength(); i++)//
    {
        temp=(s[i]-0)*k+add;//注意字符与数字之间的区别,下面也是
        s[i]=temp%10+0;
        add=temp/10;
    }
    while(add)
    {
        s[i++]=add%10+0;
        add/=10;
    }
}

int main()
{
    int n;

    while(scanf("%d",&n)!=EOF)
    {
        //初始化s
        s[0]=1;
        for(int i=1; i<=1000; i++)
        {
            s[i]=0;
        }

        //从1开始乘到n
        for(int i=1; i<=n; i++)
        {
            cal(i);
        }

        int flag=0;
        cout<<n<<"!=";
        for(int i=1000; i>=0; i--)
        {
            if(s[i]!=0)
            {
                flag=1;
            }
            if(flag)
            {
                cout<<s[i];
            }
        }
        cout<<endl;
    }
    return 0;
}

 

大数据阶乘——字符串乘法器

标签:存储   最大   大数   int   开始   cal   span   i++   ++   

原文地址:http://www.cnblogs.com/wust-owen/p/6850207.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!