HDU 1042 N!

Problem Description

Given an integer N(0 ≤ N ≤ 10000), your task is to calculate N!

Input

One N in one line, process to the end of file.

Output

For each N, output N! in one line.

Sample Input

1
2
3

Sample Output

1
2
6

题目大意:

大数阶乘,0<=n<=10000;求n的阶乘。

c++

#include <iostream>
#include<cstring>
using namespace std;
int a[1600100];
int main()
{
    int b,c,d,e,f,g;
    while(cin>>b)
    {
        memset(a,0,sizeof(a));
        a[0]=1;g=0;     //a数组中每一位用来存放一位数,g用来记录位数
        for(c=1;c<=b;c++)
        {
            for(d=0;d<=g;d++)    //a数组中每一位都与c相乘
            {
                a[d]=a[d]*c;
            }
            for(d=0;d<=g;d++)
            {
                if(a[d]>=10)    //a数组中数值>=10时进位
                {
                    a[d+1]=a[d]/10+a[d+1];
                    a[d]=a[d]%10;

                }
            }
            if(a[g+1]!=0)  //判断g的下一位是否为0
                g++;
            while(a[g]>=10)  //使a数组中每一位只存放一位数
            {
                a[g+1]=a[g]/10;a[g]=a[g]%10;g++;
            }
        }
        for(c=g;c>=0;c--)
        {
            cout<<a[c];
        }
        cout<<endl;
    }
    return 0;
}
全部评论

相关推荐

02-24 17:39
门头沟学院 Java
神哥不得了:神哥来啦~专业技能的话建议不要前面空那么多,八股的话建议先把高频top 50的八股多巩固几遍,千万不要看那些假高频八股。项目的话,建议换两个高质量的项目上去
点赞 评论 收藏
分享
ALEX_BLX:虽然说聊天记录不可信,不过这个趋势确实如此但我觉得也要想到一点就是卷后端的人里真正有“料”的人又有多少,我说的这个料都不是说一定要到大佬那种级别,而是就一个正常的水平。即使是现在也有很多人是跟风转码的,2-3个月速成后端技术栈的人数不胜数,但今时不同往日没可能靠速成进大厂了。这种情况就跟考研一样,你能上考场就已经打败一半的人了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务