【题目描述】
输入两个高精度正整数M和N(M和N均小于100位)。求这两个高精度数的积。
【输入】
输入两个高精度正整数M和N。
【输出】
求这两个高精度数的积。
【输入样例】
36
3
【输出样例】
108
答案:
#include<iostream> #include<cstring> #include<cstdio> char a1[1001],b1[1001]; //string a,b,c; int a[1001],b[1001],c[1001]; using namespace std; int main( void ) { int lena,lenb,lenc,i,j,x; memset(a,0,sizeof(a)); memset(b,0,sizeof(b)); memset(c,0,sizeof(c)); cin>>a1>>b1; //gets(a1); //gets(b1); lena=strlen(a1); lenb=strlen(b1); //123 321 for (i=0;i<=lena-1;i++) { a[lena-i]=a1[i]-48; //a[lena-i]=a1[i]-'0'; } for (i=0;i<=lenb-1;i++) { b[lenb-i]=b1[i]-48;//'0' } for (i=1;i<=lena;i++) { x=0; for (j=1;j<=lenb;j++) { c[i+j-1]=a[i]*b[j]+x+c[i+j-1]; x=c[i+j-1]/10; c[i+j-1]%=10; } c[i+lenb]=x; } lenc=lena+lenb; while (c[lenc]==0 && lenc>1) { lenc--; } for (i=lenc;i>=1;i--) { cout<<c[i]; } //cout<<endl; return 0; }