hdu_1042(模拟大数乘法)

Posted 有一天我们渺小的作为 或许 会巨大震动整个世界

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了hdu_1042(模拟大数乘法)相关的知识,希望对你有一定的参考价值。

计算n!

 1 #include<cstring>
 2 #include<cstdio>
 3 using namespace std;
 4 int num[50000];
 5 int main()
 6 {
 7     int n;
 8     while(~scanf("%d",&n))
 9     {
10         memset(num,0,sizeof(num));
11         int len = 1;
12         num[1] = 1;
13         for(int i = 2; i <= n; i++){
14             for(int j = 1; j <= len; j++){
15                 num[j] = num[j]*i;
16             }
17             for(int j = 1; j <= len; j++){
18                 if(num[j]>9) {
19                     num[j+1] += num[j]/10;
20                     num[j] = num[j]%10;
21                 }
22                 if(num[len+1]!=0) len++;
23             }
24         }
25         for(int i = len; i >= 1; i--) printf("%c",num[i]+0);
26         puts("");
27     }
28     return 0;
29 }

用大数的模板也可以,不过每次要吧数字转化成字符串,其实还是自己写比较简单,处理一个简单的进位就可以了

下面是板子:

 1 void mult(char* A,char* B,char* ans)  
 2 {  
 3     int a[size+1]= {0};  
 4     int b[size+1]= {0};  
 5     int pa=0,pb=0;  
 6     int c[2*size+1]= {0};  
 7   
 8     int lena=strlen(A);  
 9     int lenb=strlen(B);  
10   
11     for(int i=lena-1; i>=0; i--)  
12         a[pa++]=A[i]-0;  
13     for(int j=lenb-1; j>=0; j--)  
14         b[pb++]=B[j]-0;  
15   
16     for(pb=0; pb<lenb; pb++)  
17     {  
18         int w=0;  //低位到高位的进位  
19         for(pa=0; pa<=lena; pa++)  
20         {  
21             int temp=a[pa]*b[pb]+w;  
22             w=temp/10;  
23             temp=(c[pa+pb]+=temp%10);  
24             c[pa+pb]=temp%10;  
25             w+=temp/10;  
26         }  
27     }  
28     bool flag=false;  
29     bool sign=false;  //标记ans是否为全0  
30     for(pa=0,pb=lena+lenb-1; pb>=0; pb--)  
31     {  
32         if(!flag && c[pb]==0)  //删除ans开头的0  
33             continue;  
34         else  
35             flag=true;  
36   
37         sign=true;  
38         ans[pa++]=c[pb]+0;  
39     }  
40     if(sign)  
41         ans[pa]=\0;  
42     else  
43     {  
44         ans[0]=0;  
45         ans[1]=\0;  
46     }  
47   
48     return;  
49 }  
 1 string sum(string s1,string s2)  //大数加法  
 2 {  
 3     if(s1.length()<s2.length())  
 4     {  
 5         string temp=s1;  
 6         s1=s2;  
 7         s2=temp;  
 8     }  
 9     int i,j;  
10     for(i=s1.length()-1,j=s2.length()-1;i>=0;i--,j--)  
11     {  
12         s1[i]=char(s1[i]+(j>=0?s2[j]-0:0));   //注意细节  
13         if(s1[i]-0>=10)  
14         {  
15             s1[i]=char((s1[i]-0)%10+0);  
16             if(i) s1[i-1]++;  
17             else s1=1+s1;  
18         }  
19     }  
20     return s1;  
21 }  
22   
23 string Mult(string s,int x)  //大数乘以整形数  
24 {  
25     reverse(s.begin(),s.end());  
26     int cmp=0;  
27     for(int i=0;i<s.size();i++)  
28     {  
29         cmp=(s[i]-0)*x+cmp;  
30         s[i]=(cmp%10+0);  
31         cmp/=10;  
32     }  
33     while(cmp)  
34     {  
35         s+=(cmp%10+0);  
36         cmp/=10;  
37     }  
38     reverse(s.begin(),s.end());  
39     return s;  
40 }  
41 string Multfa(string x,string y)  //大数乘法  
42 {  
43     string ans;  
44     for(int i=y.size()-1,j=0;i>=0;i--,j++)  
45     {  
46         string tmp=Mult(x,y[i]-0);  
47         for(int k=0;k<j;k++)  
48             tmp+=0;  
49         ans=sum(ans,tmp);  
50     }  
51     return ans;  
52 }  

模板转自:http://blog.csdn.net/u012860063/article/details/36903491

以上是关于hdu_1042(模拟大数乘法)的主要内容,如果未能解决你的问题,请参考以下文章

hdu-1042(大数+万进制)

大数运算——hdu1042N!

HDU 1042 N!大数

HDU1042 N!(大数问题,万进制)

hdu1042 N!(大数求阶乘)

(大数 万进制) N! hdu1042