#include <bits/stdc++.h>
using namespace std;
#define N 505
void Multiply(int a[], int b[], int r[])
{
int i;
for(i = 1; i <= a[0]; ++i)
{
int c = 0;
for(int j = 1; j <= b[0]; ++j)
{
r[i+j-1] += a[i]*b[j] + c;
c = r[i+j-1] / 10;
r[i+j-1] %= 10;
}
r[i+b[0]] += c;
}
i = a[0] + b[0];
while(r[i] == 0 && i > 1)
i--;
r[0] = i;
}
void toNum(char s[], int a[])
{
a[0] = strlen(s);
for(int j= 1;j<=a[0];++j)
a[j]=s[a[0]-j]-'0';
}
void showNum(int a[])
{
for(int i=a[0];i>=1;--i)
cout << a[i];
}
int main()
{
int a[N]={},b[N]={},r[N]={};
char s[N];
cin >> s;
toNum(s, a);
cin >> s;
toNum(s, b);
Multiply(a, b, r);
showNum(r);
return 0;
}
1174:大整数乘法
于 2023-04-20 20:48:46 首次发布