这里不是必须用c++的话不推荐用c++大整数,py和java的支持要好得多。

大整数类  (非负)

#include <iostream>

#include <vector>

#include <string>

using namespace std;

struct BigInteger{

static const int BASE=100000000;

static const int WIDTH=8;

vector<int> s;

BigInteger(long long num=0){*this = 0}//构造函数

BigInteger operator =(long long num){

s.clear();

do{

s.push_back(num%BASE);

num/=BASE;

}while(num>0);

return *this;

}

BigInteger operator = (const string& str){

s.clear();

int x,len=(str.length()-1)/WIDTH+1;

for(int i=0;i<len;i++){

int end=s.length()-i*WIDTH;

int start=max(0,end-WIDTH);

sscanf(str.substr(start,end).c_str(),"%d",&x);

s.push_back(x);

}

return *this;

}

BigInteger operator + (const BigInteger &b) const {

BigInteger c;

c.s.clear();

int i,g;

int x;

for(i=0,g=0;;i++){

if(g==0&&i>=s.size()&&i>=b.s.size()){//无进位,两个BigInteger实例均已遍历完成

break;

x=g;

if(i<s.size())

x+=s[i];

if(i<b.s.size())

x+=b.s[i];

c.s.push_back(x%BASE);

g=x/BASE;

}

return c;

}

BigInteger operater+=(const BigInteger &b){

*this=*this+b;return *this;

}

BigInteger operator - (const BigInteger& b) const

{

BigInteger c;

c.s.clear();

int MAX=std::max(s.size(),b.s.size());

for(int i=0,g=0;;i++)

{

if(g==0&&i>=MAX)

break;

int x=g;

if(i<s.size())

x+=s[i];

if(i<b.s.size())

x-=b.s[i];

if(i==MAX-1)

c.s.push_back(x%BASE);

else

c.s.push_back(abs(x%BASE));

g=x/BASE;

}

return c;

}

BigInteger operator -= (const BigInteger& b)

{

*this=*this-b;

return *this;

}

BigInteger operator * (const BigInteger& b)

{

std::stringstream ss;

for(int i=s.size()-1;i>=0;i--)

ss<<s[i];

std::string operand1=ss.str();

ss.str("");

for(int i=b.s.size()-1;i>=0;i--)

ss<<b.s[i];

std::string operand2=ss.str();

std::vector<int> c,d,temp;

for(int i=operand1.length()-1;i>=0;i--)

c.push_back(operand1[i]-'0');

for(int i=operand2.length()-1;i>=0;i--)

d.push_back(operand2[i]-'0');

int MAX=std::max(c.size(),d.size());

for(int i=0;i<MAX*2+1;i++)

temp.push_back(0);

for(int i=0;i<c.size();i++)

for(int j=0;j<d.size();j++)

temp[i+j]+=c[i]*d[j];

for(int i=0;i<2*MAX+1;i++)

if(temp[i]>9)

{

temp[i+1]+=temp[i]/10;

temp[i]%=10;

}

int m=2*MAX;

while(temp[m]==0)

m--;

BigInteger another;

another.s.clear();

int len=(m-1)/WIDTH+1;

for(int i=0;i<len;i++)

another.s.push_back(0);

for(int i=0;i<len;i++)

{

int x=1;

int k=0;

int end=std::min(m+1,(i+1)*WIDTH);

int start=i*WIDTH;

for(int j=start;j<end;j++)

{

k+=x*temp[j];

x*=10;

}

another.s[i]=k;

}

return another;

}

BigInteger operator *= (const BigInteger& b)

{

*this=*this*b;

return *this;

}

//自己写的除法,可以实现像int型一样的效果

BigInteger operator / (const BigInteger& b)

{

std::string operand1,operand2,result;

std::stringstream ss;

for(int i=s.size()-1;i>=0;i--)

ss<<s[i];

operand1=ss.str();

ss.str("");

for(int i=b.s.size()-1;i>=0;i--)

ss<<b.s[i];

operand2=ss.str();

int len1,len2;

len1=operand1.length();

len2=operand2.length();

if(len1<len2)  //若操作数1小于操作数2,返回0

return 0;

if(*this==b)    //若两数相等,返回1,这里用到下面的“==”重载运算符

return 1;

std::vector<int> c,d;

for(int i=0;i<len1;i++)

{

c.push_back(operand1[i]-'0');

if(i<len2)

d.push_back(operand2[i]-'0');

else

d.push_back(0);

}

int time=len1-len2;

int len=len1;

int k,l=0;

for(int i=0;i<=time;i++)

{

int ok=1;

k=0;

do{

if(c[l]==0)

{

l++;

ok=0;

len1--;

}

if(len==len1)

{

int j=0;

while(j<len2)

{

if(c[i+j]>d[j])    //第一次大就表示operand1 > operand2

{

ok=1;

break;

}

else if(c[i+j]<d[j])      //第一次小就表示operand1 < operand2

{

ok=0;

break;

}

j++;

}

}

if(ok)

{

for(int j=0;j<len;j++)

{

c[j+i]-=d[j];

if(c[j+i]<0)

{

c[j+i-1]--;

c[j+i]+=10;

}

}

k++;

}

}while(ok);

len--;

result+=k+'0';

}

BigInteger temp;

temp=result;

return temp;

}

BigInteger operator /= (const BigInteger& b)

{

*this=*this/b;

return *this;

}

//以下的重载方法全都在上面的四则运算上编写,不再介绍

BigInteger operator % (const BigInteger& b)

{

BigInteger c;

c=*this-(*this/b)*b;

return c;

}

BigInteger operator %= (const BigInteger& b)

{

*this=*this%b;

return *this;

}

bool operator < (const BigInteger& b) const

{

if(s.size()!=b.s.size())

return s.size()<b.s.size();

for(int i=s.size()-1;i>=0;i--)

if(s[i]!=b.s[i])

return  s[i]<b.s[i];

return false;//相等

}

bool operator > (const BigInteger& b) const

{

return b<*this;

}

bool operator <= (const BigInteger& b) const

{

return !(b<*this);

}

bool operator >= (const BigInteger& b) const

{

return !(*this<b);

}

bool operator != (const BigInteger& b) const

{

return *this<b||*this>b;

}

bool operator == (const BigInteger& b) const

{

return !(*this<b)&&!(*this>b);

}

friend std::ostream& operator << (std::ostream& out,const BigInteger& x)

{

out<<x.s.back();

for(int i=x.s.size()-2;i>=0;i--)

{

char buf[20];

sprintf(buf,"%08d",x.s[i]);

for(int j=0;j<strlen(buf);j++)

out<<buf[j];

}

return out;

}

friend std::istream& operator >> (std::istream& in,BigInteger& x)

{

std::string s;

if(!(in>>s))

return in;

x=s;

return in;

}

};

istream& operator >> (istream &in, BigInteger &x){

string s;

if(!(in>>x)) return in;

x=s;

return in;

}

ostream& operator << (ostream &out,const BigInteger &x){

out << x.s.back();//最高位不足8位的预防处理

int i;

for(i=x.s.size()-2;i>=0;i--){

char buf[20];

sprintf(buf,"%08d",x.s[i]);//不足8位补0

for(int j=0;j<strlen(buf);j++)

out<<buf[j];

}

return out;

}

说明:    static const int BASE=100000000;这个常数不属于 BigInteger类型的结构体变量,而属于 BigInteger这个类型,称为静态成员变量。在 BigInteger的成员函数内可以直接使用,但是在其他地方,用 BigInteger::BASE

c++大整数的更多相关文章

  1. poj2389-Bull Math(大整数乘法)

    一,题意: 大整数乘法模板题二,思路: 1,模拟乘法(注意"逢十进一") 2,倒序输出(注意首位0不输出) 三,步骤: 如:555 x 35 = 19425  5 5 5  5 5 ...

  2. AC日记——大整数的因子 openjudge 1.6 13

    13:大整数的因子 总时间限制:  1000ms 内存限制:  65536kB 描述 已知正整数k满足2<=k<=9,现给出长度最大为30位的十进制非负整数c,求所有能整除c的k. 输入 ...

  3. Ac日记——大整数减法 openjudge 1.6 11

    11:大整数减法 总时间限制:  1000ms 内存限制:  65536kB 描述 求两个大的正整数相减的差. 输入 共2行,第1行是被减数a,第2行是减数b(a > b).每个大整数不超过20 ...

  4. AC日记——大整数加法 openjudge 1.6 10

    10:大整数加法 总时间限制:  1000ms 内存限制:  65536kB 描述 求两个不超过200位的非负整数的和. 输入 有两行,每行是一个不超过200位的非负整数,可能有多余的前导0. 输出 ...

  5. vijos-1447 开关灯泡-大整数开方算法

    描述 一个房间里有n盏灯泡,一开始都是熄着的,有1到n个时刻,每个时刻i,我们会将i的倍数的灯泡改变状态(即原本开着的现将它熄灭,原本熄灭的现将它点亮),问最后有多少盏灯泡是亮着的. 提示 范围:40 ...

  6. poj2305-Basic remains(进制转换 + 大整数取模)

    进制转换 + 大整数取模一,题意: 在b进制下,求p%m,再装换成b进制输出. 其中p为b进制大数1000位以内,m为b进制数9位以内二,思路: 1,以字符串的形式输入p,m; 2,转换:字符串-&g ...

  7. [转载]JavaScript 中小数和大整数的精度丢失

    标题: JavaScript 中小数和大整数的精度丢失作者: Demon链接: http://demon.tw/copy-paste/javascript-precision.html版权: 本博客的 ...

  8. ACM学习之路————一个大整数与一个小整数不得不说得的秘密

    这个相对于两个大整数的运算来说,只能说是,low爆了. 只要利用好除法的性质,这类题便迎刃而解.O(∩_∩)O哈哈~ //大整数除一个int数 #include<iostream> #in ...

  9. 华为"128为大整数相加"机试题

    最近正直春招,偶尔接触到了华为的这道大整数相加的测试题,在网上找了一个算法,然后自己尝试进行了优化,最后也对memmove()函数效率有了进一步把握. #include <time.h># ...

  10. POJ C++程序设计 编程题#1 大整数的加减乘除

    编程题#4:大整数的加减乘除 来源: POJ (Coursera声明:在POJ上完成的习题将不会计入Coursera的最后成绩.) 注意: 总时间限制: 1000ms 内存限制: 65536kB 描述 ...

随机推荐

  1. SparkStreaming和Kafka基于Direct Approach如何管理offset实现exactly once

    在之前的文章<解析SparkStreaming和Kafka集成的两种方式>中已详细介绍SparkStreaming和Kafka集成主要有Receiver based Approach和Di ...

  2. IP2188中文资料书

    IP2188 是一款集成 12 种.用于 USB 输出端口的快充协议 IC,支持 USB 端口充电协议.支持 11种快充协议,包括 USB TypeC PD2.0/PD3.0/PPS DFP,HVDC ...

  3. 特征预处理之归一化&标准化

    写在前面 这篇博客的主要内容 应用MinMaxScaler实现对特征数据进行归一化 应用StandardScaler实现对特征数据进行标准化 特征预处理 定义 ​ 通过一些转换函数将特征数据转换成更加 ...

  4. ftp上传文件出现553 Could not creat files 严重文件传输错误

    之前上传文件到云服务器上一直出错,发现可以下载但是不能上传和编辑,后来终于找到原因了,是因为上传文件所在文件夹默认只有root用户才有写权限,所以我们还要将写权限赋予给其他用户.可以用Xshell 5 ...

  5. code-server Command ' ' not found

    由于通过一些特殊的方式登录linux用户后,全局变量不会自动加载,需要在 vscode 的 bash terminal手动读取 输入 source /etc/profile 或者vim ~/.bash ...

  6. It is thread-safe and idempotent, but not reentrant.

    https://github.com/django/django/blob/master/django/apps/registry.py

  7. 多线程c++11编程题目

    /*题目:子线程循环 10 次,接着主线程循环 100 次,接着又回到子线程循环 10 次,接着再回到主线程又循环 100 次. 如此循环50次,试写出代码.子线程与主线程必有一个满足条件(flag ...

  8. WireShark 之 text2pcap

    前言 本来想用 010Editer 的,看到破解教程头都大了,那么就用 WireShark 的 Text2pcap 吧! 正文 打开CMD控制台窗口,转到WireShark安装目录 ,此处可以shif ...

  9. ElasticSearch基本简介(一)

    一.ES简介 1,什么是ES ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式的全文搜索引擎,其对外服务是基于RESTful web接口发布的.Elasticsearc ...

  10. loj10002喷水装置

    长L米,宽W米的草坪里装有N  个浇灌喷头.每个喷头都装在草坪中心线上(离两边各 W/2米).我们知道每个喷头的位置(离草坪中心线左端的距离),以及它能覆盖到的浇灌范围. 请问:如果要同时浇灌整块草坪 ...