(压位)高精模板
copy了一下大佬的高精博客,主要是为了能用着方便
大佬Last-Order的原博客
模板
高精度算法(High Accuracy Algorithm)是处理大数字的数学计算方法。
这里使用了压位高精。(既然写了高精就要让他做到最好!)
经极其不完全统计,压位高精取1e7进制时较快。
总模板(直接复制这里)
const int bse = 1e7;
struct haa{
ll a[105];int len;
haa(){len = 1, memset(a,0,sizeof(a));}
haa(int x){
memset(a,0,sizeof(a));len = 1;
while(x){a[len++] = x % bse,x /= bse;}len --;
}
void print(){
printf("%lld",a[len]);
for(int i = len-1 ; i ; i --)printf("%07lld",a[i]);
}
};
haa operator + (haa& a,haa& b){
haa ret = 0; ret.len = max(a.len,b.len) + 1;
for(int i = 1 ; i <= ret.len ; i ++)
ret.a[i] += a.a[i] + b.a[i],
ret.a[i+1] += ret.a[i] / bse,
ret.a[i] %= bse;
for(int i = 1 ; i <= ret.len ; i ++)
ret.a[i+1] += ret.a[i] / bse,
ret.a[i] %= bse;
while(ret.len > 1 && !ret.a[ret.len]) ret.len --;
return ret;
}
haa operator * (haa& a,haa& b){
haa ret = 0; ret.len = a.len + b.len + 1;
for(int i = 1 ; i <= a.len ; i ++)
for(int j = 1 ; j <= b.len ; j ++)
ret.a[i+j-1] += a.a[i] * b.a[j],
ret.a[i+j] += ret.a[i+j-1] / bse,
ret.a[i+j-1] %= bse;
for(int i = 1 ; i <= ret.len ; i ++)
ret.a[i+1] += ret.a[i] / bse ,
ret.a[i] %= bse;
while(ret.len > 1 && !ret.a[ret.len]) ret.len --;
return ret;
}
haa operator * (haa& a,int b){
haa ret = 0 ; ret.len = a.len;
int x = b;
while(x) ret.len ++ , x /= bse;
for(int i = 1 ; i <= a.len ; i ++)
ret.a[i] += a.a[i] * b,
ret.a[i+1] += ret.a[i] / bse,
ret.a[i] %= bse;
for(int i = 1 ; i <= ret.len ; i ++)
ret.a[i+1] += ret.a[i] / bse,
ret.a[i] %= bse;
while(ret.len > 1 && !ret.a[ret.len]) ret.len --;
return ret;
}
inline void operator += (haa& a,haa& b){a = a+b;}
inline void operator *= (haa& a,int b){a = a*b;}
inline void operator *= (haa& a,haa& b){a = a*b;}
bool operator < (const haa& a,const haa& b){
if(a.len != b.len) return a.len < b.len;
for(int i = a.len ; i ; i --)
if(a.a[i] != b.a[i]) return a.a[i] < b.a[i];
return 0;
}
bool operator == (const haa& a,const haa& b){
if(a.len != b.len) return 0;
for(int i = a.len ; i ; i --)
if(a.a[i] != b.a[i]) return 0;
return 1;
}
bool operator > (const haa& a,const haa& b){return !(a<b) && !(a == b);}
以下具体说明。
声明部分(内含构造函数及输出)
const int bse = 1e7;//若需修改进制,修改此处即可
struct haa{
ll a[105];int len;
haa(){len = 1, memset(a,0,sizeof(a));}
haa(int x){
memset(a,0,sizeof(a));len = 1;
while(x){a[len++] = x % bse,x /= bse;}len --;
}
void print(){
printf("%lld",a[len]);
for(int i = len-1 ; i ; i --)printf("%07lld",a[i]);
}
};
此时,向高精赋值可以写作:
或者可以写作:haa a = read();。
输出某值可以直接写成:
haa a = /*...*/;
a.print();
高精+高精
haa operator + (haa& a,haa& b){
haa ret = 0; ret.len = max(a.len,b.len) + 1;
for(int i = 1 ; i <= ret.len ; i ++)
ret.a[i] += a.a[i] + b.a[i],
ret.a[i+1] += ret.a[i] / bse,
ret.a[i] %= bse;
for(int i = 1 ; i <= ret.len ; i ++)
ret.a[i+1] += ret.a[i] / bse,
ret.a[i] %= bse;
while(ret.len > 1 && !ret.a[ret.len]) ret.len --;
return ret;
}
inline void operator += (haa& a,haa& b){a = a+b;}
调用时,写作a = a + b或a += b。
高精×低精
haa operator * (haa& a,int b){
haa ret = 0 ; ret.len = a.len;
int x = b;
while(x) ret.len ++ , x /= bse;
for(int i = 1 ; i <= a.len ; i ++)
ret.a[i] += a.a[i] * b,
ret.a[i+1] += ret.a[i] / bse,
ret.a[i] %= bse;
for(int i = 1 ; i <= ret.len ; i ++)
ret.a[i+1] += ret.a[i] / bse,
ret.a[i] %= bse;
while(ret.len > 1 && !ret.a[ret.len]) ret.len --;
return ret;
}
inline void operator *= (haa& a,int b){a = a*b;}
调用同上。
高精×高精
haa operator * (haa& a,haa& b){
haa ret = 0; ret.len = a.len + b.len + 1;
for(int i = 1 ; i <= a.len ; i ++)
for(int j = 1 ; j <= b.len ; j ++)
ret.a[i+j-1] += a.a[i] * b.a[j],
ret.a[i+j] += ret.a[i+j-1] / bse,
ret.a[i+j-1] %= bse;
for(int i = 1 ; i <= ret.len ; i ++)
ret.a[i+1] += ret.a[i] / bse ,
ret.a[i] %= bse;
while(ret.len > 1 && !ret.a[ret.len]) ret.len --;
return ret;
}
inline void operator *= (haa& a,haa& b){a = a*b;}
调用同上。
判断符
bool operator < (const haa& a,const haa& b){
if(a.len != b.len) return a.len < b.len;
for(int i = a.len ; i ; i --)
if(a.a[i] != b.a[i]) return a.a[i] < b.a[i];
return 0;
}
bool operator == (const haa& a,const haa& b){
if(a.len != b.len) return 0;
for(int i = a.len ; i ; i --)
if(a.a[i] != b.a[i]) return 0;
return 1;
}
bool operator > (const haa& a,const haa& b){return !(a<b) && !(a == b);}
调用同其他。
可以直接使用max,min等函数。