标签:
2
3
6
代码:
#include <iostream> #include <cstdio> #include <cstring> using namespace std; char a[10001];//储存a,由低位到高位 char b[10001];//储存a,由低位到高位 char c1[10001];//临时存储 char c2[10001];//临时存储 int f[20000]={0};//存放结果,逆序 void cheng(int la,int lb){ int k=0; int ge; int shi; if(la>=lb){ for(int i=0;i<lb;i++){ for(int j=0;j<la;j++){ f[k+j]+=(a[j]-‘0‘)*(b[i]-‘0‘); } k++; } for(int l=0;l<=(la+lb-1);l++){ if(f[l]>=10){ ge=f[l]%10; shi=f[l]/10; f[l]=ge; f[l+1]+=shi; } } } if(la<lb){ for(int i=0;i<la;i++){ for(int j=0;j<lb;j++){ f[k+j]+=(b[j]-‘0‘)*(a[i]-‘0‘); } k++; } for(int l=0;l<=(lb+la-1);l++){ if(f[l]>=10){ ge=f[l]%10; shi=f[l]/10; f[l]=ge; f[l+1]+=shi; } } } } void print(int l){ int k=0; for(int j=l;j>=0;j--){ if(f[j]==0){ k++; }else{ break; } } if(k==l+1){ printf("0"); }else{ for(int i=l-k;i>=0;i--){ printf("%d",f[i]); } } } int main() { int la; int lb; while(scanf("%s %s",c1,c2)!=EOF){ la=strlen(c1); for(int i=0;i<la;i++){ a[i]=c1[la-1-i]; } lb=strlen(c2); for(int i=0;i<lb;i++){ b[i]=c2[lb-1-i]; } cheng(la,lb); print(la+lb-1); printf("\n"); memset(f,0,20000*sizeof(int)); } return 0; }
标签:
原文地址:http://www.cnblogs.com/TWS-YIFEI/p/5677572.html