今天无意间看到一个很好的大数模板,能算加、减、乘、除等基本运算,但操作减法的时候只能大数减小数,也不支持负数,如果是两个负数的话去掉符号相加之后再取反就可以了,一正一负比较绝对值大小,然后相减。我借用了一下:(作过少许代码上的精简)

#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<iostream>
using namespace std; const int maxn = ; struct bign{
int len, s[maxn];
bign(){
memset(s,,sizeof(s));
len= ;
}
bign(int num) { *this = num; }
bign(const char *num) { *this = num; }
bign operator = (const int num){
char s[maxn];
sprintf(s,"%d",num);
return *this = s;
}
bign operator = (const char *num){
for(int i = ; num[i] && num[i] ==''; ++num) ;
len = strlen(num);
for(int i = ; i < len; ++i)
s[i] = num[len--i] -'';
return *this;
}
bign operator + (const bign &b) const {
bign c;
c.len = ;
int maxlen = max(len, b.len);
for(int i = , g = ; g || i < maxlen; ++i){ // g是进位
int x = g;
if(i < len) x += s[i];
if(i < b.len) x += b.s[i];
c.s[c.len++] = x % ;
g = x / ;
}
return c;
}
bign operator += (const bign &b){
return *this = *this + b;
}
void clean(){
while(len > && !s[len-]) --len;
}
bign operator * (const bign &b) const {
bign c;
c.len = len + b.len; for(int i = ; i < len; ++i)
for(int j = ; j < b.len; ++j)
c.s[i+j] += s[i] * b.s[j]; for(int i = ; i < c.len; ++i){
c.s[i+] += c.s[i]/;
c.s[i] %= ;
}
c.clean();
return c;
}
bign operator *= (const bign &b){
return *this = *this * b;
}
bign operator -(const bign &b) const {
bign c;
c.len = ;
for(int i = , g = ; i < len; ++i){ //此时的 g是退位
int x = s[i]- g;
if(i < b.len) x -= b.s[i];
if(x >= ) g = ;
else {
g = ;
x += ;
}
c.s[c.len++] = x;
}
c.clean();
return c;
}
bign operator -= (const bign &b){
return *this = *this - b;
}
bign operator / (const bign &b) const {
bign c, f = ;
for(int i = len-; i >= ; --i){
f *= ;
f.s[] = s[i];
while(f >= b){
f -= b;
++c.s[i];
}
}
c.len = len;
c.clean();
return c;
}
bign operator /= (const bign &b){
return *this = *this / b;
}
bign operator % (const bign &b) const {
bign r = *this / b;
return *this- r*b;
}
bign operator %= (const bign &b){
return *this = *this % b;
}
bool operator < (const bign &b) const {
if(len != b.len) return len < b.len;
for(int i= len-; i>=; --i)
if(s[i] != b.s[i]) return s[i] < b.s[i];
return ;
}
bool operator > (const bign &b) const {
if(len != b.len) return len > b.len;
for(int i = len-; i >= ; --i)
if(s[i] != b.s[i]) return s[i] > b.s[i];
return ;
}
bool operator == (const bign &b) const {
return !(*this < b || *this > b);
}
bool operator != (const bign &b) const {
return !(*this == b);
}
bool operator <= (const bign &b) const {
return *this < b || *this == b;
}
bool operator >= (const bign &b) const {
return *this > b || *this == b;
}
string str() const {
string res = "";
for(int i = ; i < len; ++i)
res = char(s[i]+'') + res; //这里一定不能掉乱 +的顺序!
return res;
}
}; istream& operator >> (istream &in, bign &x){
string s;
in >> s;
x = s.c_str();
return in;
} ostream& operator << (ostream &out, const bign &x){
out << x.str();
return out;
} int main()
{
bign a,b,c,d,e,f,g;
while(cin>>a>>b)
{
a.clean();
b.clean();
c = a+b;
d = a-b;
e = a*b;
f = a/b;
g = a%b;
cout<<"a+b = "<<c<<endl;
cout<<"a-b = "<<d<<endl;
cout<<"a*b = "<<e<<endl;
cout<<"a/b = "<<f<<endl;
cout<<"a%b = "<<g<<endl;
cout<<(a==b? "a = b":"a != b")<<endl;
}
return ;
}

  在此感谢原博客的模板提供: bign类C++高精度模板

bignum 大数模板的更多相关文章

  1. hdu 5429 Geometric Progression(存个大数模板)

    Problem Description Determine whether a sequence is a Geometric progression or not. In mathematics, ...

  2. 【集训笔记】【大数模板】特殊的数 【Catalan数】【HDOJ1133【HDOJ1134【HDOJ1130

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3324 http://blog.csdn.net/xymscau/artic ...

  3. hdu1042(大数模板)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1042 在网上找了个大数模板方便以后用得到. #include<iostream> #inc ...

  4. 大数模板 poj3982

    1. 这个模板不是自己写的,转载的别人转载的,还没学完c++的我,想写也没有那能力. 这个模板我用在了POJ的一道题上,传送门--POJ3982 一般大数的题,都可用这个模板解决,仅仅须要改动主函数就 ...

  5. Hdu 4762 网络赛 高精度大数模板+概率

    注意题目中的这句话he put the strawberries on the cake randomly one by one,第一次选择草莓其实有N个可能,以某一个草莓为开头,然后顺序的随机摆放, ...

  6. vijos - P1447开关灯泡 (大数模板 + 找规律 + 全然数 + python)

    P1447开关灯泡 Accepted 标签:CSC WorkGroup III[显示标签] 描写叙述 一个房间里有n盏灯泡.一開始都是熄着的,有1到n个时刻.每一个时刻i,我们会将i的倍数的灯泡改变状 ...

  7. c++大数模板

    自己写的大数模板,参考了小白书上的写法,只是实现了加减乘法,不支持负数,浮点数.. 除法还没写o(╯□╰)o以后再慢慢更吧.. 其实除法我用(xie)的(bu)少(lai),乘法写过fft,这模板还是 ...

  8. ACM大数模板(支持正负整数)

    之前就保留过简陋的几个用外部数组变量实现的简单大数模板,也没有怎么用过,今天就想着整合封装一下,封装成C++的类,以后需要调用的时候也方便得多. 实现了基本的加减乘除和取模运算的操作符重载,大数除以大 ...

  9. 大数模板 (C ++)

    上次BC遇到一个大数题目,没有大数模板和不会使用JAVA的同学们GG了,赛后从队友哪里骗出大数模板.2333333,真的炒鸡nice(就是有点长),贴出来分享一下好辣. //可以处理字符串前导零 #i ...

随机推荐

  1. ACM第四站————最小生成树(普里姆算法)

    对于一个带权的无向连通图,其每个生成树所有边上的权值之和可能不同,我们把所有边上权值之和最小的生成树称为图的最小生成树. 普里姆算法是以其中某一顶点为起点,逐步寻找各个顶点上最小权值的边来构建最小生成 ...

  2. 修改tomcat的logo

    每页的<head> 里添加   <link rel="icon" href="favicon.gif" />   图片名称必须是favi ...

  3. HDU 2067:小兔的棋盘

    小兔的棋盘 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  4. c# XML省市联动

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...

  5. C/C++ 调用qsort/sort 对字符数组排序的cmp函数写法

    这个问题屡次碰到解决之后再次遇到又忘记怎么弄了,这次打算彻底搞清楚. ·C 首先对所谓字符数组的排序应该是对(char)*a[]数组而非(char)a[][]进行的排序,后者是无法直接调用qsort实 ...

  6. Unity重力的测试

    其实和想象的结果还是有点出入 斜坡测试 (非悬空,直接把地面旋转成斜坡) 在非悬空状态下是不会受到斜坡的影响,只有进入悬空再进入斜坡,才会滑下去 一帧内关闭碰撞器再打开,或者一帧内打开Trigger再 ...

  7. java 反编译和文档生成器

    挺有趣的东西. 代码在上一篇中有. 反编译器javap.exe javadoc.exe制作源文件类结构的html格式文档

  8. Java提高篇---TreeMap

    TreeMap的实现是红黑树算法的实现,所以要了解TreeMap就必须对红黑树有一定的了解,其实这篇博文的名字叫做:根据红黑树的算法来分析TreeMap的实现,但是为了与Java提高篇系列博文保持一致 ...

  9. 2016年11月25日 星期五 --出埃及记 Exodus 20:16

    2016年11月25日 星期五 --出埃及记 Exodus 20:16 "You shall not give false testimony against your neighbor.不 ...

  10. 01scala环境搭建和基础

    1.环境搭建 1.下载安装jdk1.7以上版本,并进行环境变量的配置 2.下载scala-2.10.4.msi,安装后进行环境变量的配置 3.下载scala-SDK-4.1.1-vfinal-2.11 ...