kuangbin大数模板(加法和乘法)
生活随笔
收集整理的這篇文章主要介紹了
kuangbin大数模板(加法和乘法)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
之前的模板因為用了string類,以及運算的時候常數太大,導致速度太慢,雖然比較方便但不算很通用,所以存一波kuangbin大大的模板
/** 高精度,支持乘法和加法*/ struct BigInt {const static int mod = 10000;const static int DLEN = 4;int a[600],len;BigInt(){memset(a,0,sizeof(a));len = 1;}BigInt(int v){memset(a,0,sizeof(a));len = 0;do{a[len++] = v%mod;v /= mod;}while(v);}BigInt(const char s[]){memset(a,0,sizeof(a));int L = strlen(s);len = L/DLEN;if(L%DLEN)len++;int index = 0;for(int i = L-1;i >= 0;i -= DLEN){int t = 0;int k = i - DLEN + 1;if(k < 0)k = 0;for(int j = k;j <= i;j++)t = t*10 + s[j] - '0';a[index++] = t;}}BigInt operator +(const BigInt &b)const{BigInt res;res.len = max(len,b.len);for(int i = 0;i <= res.len;i++)res.a[i] = 0;for(int i = 0;i < res.len;i++){res.a[i] += ((i < len)?a[i]:0)+((i < b.len)?b.a[i]:0);res.a[i+1] += res.a[i]/mod;res.a[i] %= mod;}if(res.a[res.len] > 0)res.len++;return res;}BigInt operator *(const BigInt &b)const{BigInt res;for(int i = 0; i < len;i++){int up = 0;for(int j = 0;j < b.len;j++){int temp = a[i]*b.a[j] + res.a[i+j] + up;res.a[i+j] = temp%mod;up = temp/mod;}if(up != 0)res.a[i + b.len] = up;}res.len = len + b.len;while(res.a[res.len - 1] == 0 &&res.len > 1)res.len--;return res;}void output(){printf("%d",a[len-1]);for(int i = len-2;i >=0 ;i--)printf("%04d",a[i]);printf("\n");} };?
總結
以上是生活随笔為你收集整理的kuangbin大数模板(加法和乘法)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 牛客 - 牛牛的Link Power I
- 下一篇: HDU - 2825 Wireless