1 #include<stdio.h> 2 #include<string.h> 3 char s[1000]; 4 void mult(char a[],char b[]) 5 { 6 int i,j,k=0,alen,blen,sum=0,res[500][500]={0},flag=0; 7 char result[500]; 8 alen=strlen(a);blen=strlen(b); 9 10 for (i=0;i<alen;i++) 11 for (j=0;j<blen;j++) res[i][j]=(a[i]-'0')*(b[j]-'0'); 12 13 for (i=alen-1;i>=0;i--) 14 { 15 for (j=blen-1;j>=0;j--) sum=sum+res[i+blen-j-1][j]; 16 result[k]=sum; 17 k=k+1; 18 sum=sum/10; 19 } 20 21 for (i=blen-2;i>=0;i--) 22 { 23 for (j=0;j<=i;j++) sum=sum+res[i-j][j]; 24 result[k]=sum; 25 k=k+1; 26 sum=sum/10; 27 } 28 if (sum!=0) {result[k]=sum;k=k+1;} 29 30 for (i=0;i<k;i++) result[i]+='0'; 31 for (i=k-1;i>=0;i--) s[i]=result[k-1-i]; 32 s[k]='\0'; 33 34 while(1) 35 { 36 if (strlen(s)!=strlen(a)&&s[0]=='0') 37 strcpy(s,s+1); 38 else 39 break; 40 } 41 } 42 int main(){ 43 char str1[1000],str2[1000]; 44 int t,frag,i; 45 // while(scanf("%s%s",str1,str2)!=EOF){ 46 scanf("%s%s",str1,str2); 47 mult(str1,str2); 48 frag=0; 49 t=strlen(s); 50 for(i=0;i<t;i++){ 51 if(s[i]!='0') 52 frag=1; 53 if(frag==1) 54 printf("%c",s[i]); 55 } 56 if(frag==0) 57 printf("0"); 58 // } 59 return 0; 60 }