#include<iostream>
#include<algorithm>
using namespace std;
#define maxn 100
struct Bigint{
int len, a[maxn];
Bigint(int x=0){
a[maxn]={0};
for(len=1; x; len++){
a[len]=x%10;
x/=10;
}
len--;
}
int &operator[](int i){
return a[i];
}
void flatten(int L){
len=L;
for(int i=1; i<=len; i++){
a[i+1]+=a[i]/10;
a[i]%=10;
}
for(; !a[len]; ){
len--;
}
}
void print(){
for(int i=max(len, 1); i>=1; i--){
cout<<a[i];
}
}
};
Bigint operator+(Bigint a, Bigint b){
Bigint c;
int len=max(a.len, b.len);
for(int i=1; i<=len; i++){
c[i]+=a[i]+b[i];
}
c.flatten(len+11);
return c;
}
Bigint operator*(Bigint a, int b){
Bigint c;
int alen=a.len;
for(int i=1; i<alen; i++){
c[i]=a[i]*b;
}
c.flatten(alen+11);
return c;
}
大佬们看一下,哪里错了???