/*
高精度乘法
A*B
我们将B看成一个整体
A最低位对应位置的数字应该是 A最低位的数字*B%10 向上进的数字是所的数字/10
A次低位对应位置的数字应该是 A次低位的数字*10+进位的数字%10 向上进的数字是所的数字/10
这就是高精度乘法的原理
下面是一个很长的数字乘以一个很短的数字的代码实现过程
*/
#include<iostream>
#include<vector>
using namespace std;
vector<int> mul(vector<int> &A,int b){
vector<int> C;
int t=0;//t表示进位的数字
for(int i=0;i<A.size()||t;i++){//这个t表示t!=0也就是说还有进位的时候程序要继续执行
if(i<A.size()) t+=A[i]*b;
C.push_back(t%10);
t/=10;
}
return C;
}
int main(){
string a;
int b;
cin>>a>>b;
vector<int> A;
for(int i=a.size()-1;i>=0;i--) A.push_back(a[i]-'0');
vector<int> C=mul(A,b);
for(int i=C.size()-1;i>=0;i--) printf("%d",C[i]);
return 0;
}