HDoj-1042 大數階乘

來源:互聯網
上載者:User

標籤:c語言   algorithm   namespace   printf   c   

N!
Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 53785    Accepted Submission(s): 15217

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

#include<stdio.h> #include<string.h>const int maxn=50000;    //數組開到50000就可以滿足10000的階乘不越界 int fun[maxn];int main(){int i,j,n;while(~scanf("%d",&n)){    memset(fun,0,sizeof(fun));   fun[0]=1;   for(i=2;i<=n;i++)          //從2的階乘開始,一直到指定數的階乘    {   int c=0;    for(j=0;j<maxn;j++)  //將所得階乘數放在fun數組中,低位放在fun[0]中     {    int s=fun[j]*i+c;      fun[j] =s%10;      c=s/10;        }       }         for(j=maxn-1;j>=0;j--)     //找出該數的最高位,即數組角碼最大且不為0的數             if(fun[j])  break;  for(i=j;i>=0;i--)            printf("%d",fun[i]);   printf("\n");}return 0;}

HDoj-1042 大數階乘

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.