第五章Biginteger的部分实现

  1 #include <cstdio>
  2 #include <iostream>
  3 #include <vector>
  4
  5 using namespace std;
  6
  7 struct BigInteger
  8 {
  9     static const int BASE=1000000000;
 10     static const int WIDTH=8;
 11
 12     vector<int> s;
 13
 14     BigInteger(long long int num=0){ *this=num; }
 15
 16     BigInteger operator=(long long num)
 17     {
 18         s.clear();
 19
 20         do
 21         {
 22             s.push_back(num%BASE);
 23             num/=BASE;
 24
 25         }while(num>0);
 26
 27         return *this;
 28     }
 29
 30     BigInteger operator=(const string& num)
 31     {
 32         s.clear();
 33
 34         for(int end=num.length()-1;;)
 35         {
 36             int x,start=end-WIDTH+1;
 37
 38             if(start>=0)
 39             {
 40                 sscanf(num.substr(start,WIDTH).c_str(),"%d",&x);
 41                 s.push_back(x);
 42                 end=start-1;
 43             }
 44             else if(end>=0)
 45             {
 46                 sscanf(num.substr(0,end+1).c_str(),"%d",&x);
 47                 s.push_back(x);
 48                 break;
 49             }
 50             else
 51                 break;
 52         }
 53
 54         return *this;
 55     }
 56
 57     BigInteger operator+(const BigInteger& b)
 58     {
 59         BigInteger c;
 60         c.s.clear();                 //必须先clear为空不然会有一个默认的0值在c.s 中
 61
 62         int c1=0;
 63
 64         for(unsigned int i=0;;i++)
 65         {
 66             if(i<s.size() && i<b.s.size())
 67             {
 68                 int sum=s[i]+b.s[i]+c1;
 69                 c1=sum/BASE;
 70                 sum%=BASE;
 71                 c.s.push_back(sum);
 72             }
 73             else if(i<s.size() && i>=b.s.size())
 74             {
 75                 int sum=s[i]+c1;
 76                 c.s.push_back(sum);
 77                 c1=0;
 78             }
 79             else if(i>=s.size() && i<b.s.size())
 80             {
 81                 int sum=b.s[i]+c1;
 82                 c.s.push_back(sum);
 83                 c1=0;
 84             }
 85             else
 86                 break;
 87         }
 88
 89         return c;
 90     }
 91
 92     bool operator<(const BigInteger& b)
 93     {
 94         if(s.size()!=b.s.size()) return s.size()<b.s.size();
 95
 96         for(unsigned int i=s.size()-1;i>=0;i--)
 97             if(s[i]!=b.s[i])
 98                 return s[i]<b.s[i];
 99
100         return false;
101     }
102
103     friend ostream& operator<<(ostream& out,const BigInteger& x);
104     friend istream& operator>>(istream& in,const BigInteger& x);
105 };
106
107 ostream& operator<<(ostream& out,const BigInteger& x)
108 {
109
110
111     for(int i=x.s.size()-1;i>=0;i--)
112         out<<x.s[i];
113
114          //cout<<x.s.size()<<endl;
115     return out;
116 }
117
118 istream& operator>>(istream& in,BigInteger& x)
119 {
120     string s;
121     if(!(in>>s)) return in;
122
123     x=s;
124     return in;
125 }
126
127 int main()
128 {
129     BigInteger bi1;
130     BigInteger bi2;
131
132     cin>>bi1;
133     cin>>bi2;
134
135
136     if(bi1<bi2)
137     {
138         cout<<bi1<<endl;
139         cout<<bi2<<endl;
140     }
141     else
142     {
143         cout<<bi2<<endl;
144         cout<<bi1<<endl;
145     }
146
147     cout<<bi2+bi1<<endl;
148     return 0;
149
150 }
时间: 2024-10-14 00:57:49

第五章Biginteger的部分实现的相关文章

第五章Biginteger部分实现

1 #include <cstdio> 2 #include <iostream> 3 #include <vector> 4 5 using namespace std; 6 7 struct BigInteger 8 { 9 static const int BASE=100000000; 10 static const int WIDTH=8; 11 12 vector<int> s; 13 14 BigInteger(long long int nu

《大道至简》第五章读后感

失败的过程也是过程,我觉得这句话很有深意,阅读完大道至简第五章,我又有了很深的感触. 首先是“做过程不是做工程”,过程是为了实现某种目的而经历的一些事情,过程有很多种,虽然经历了某种过程,但不一定能实现某种功能.做完过程的每一个阶段,并不等于做工程.做过程不是做工程的精义,也不是最终目的. 然后是“做过场”,做过场就好像是一种形式一样,做了没必要做的事情,就是浪费时间. 做工程的最终目的是实现客户的要求,工程只是一种实现的途径.最初做开发的前辈们,不用什么工程或者过程,也一样编出了程序,也一样解

大道至简第五章读后感

第五章 失败的过程也是过程 今天照样老师带领着我们阅读了大道至简第五章,阅读了<大道至简>的第五章,这章在前面的基础上又进了一步,有了技术和团队,加上有效的沟通,接下来就要接项目做工程. “虚有其表耳”,本章以<明皇实录>中的一句话来告诉我们一个深刻的道理:不要只求外表,只做形象工程,而是要透过表象,力求实质. 失败了不要紧,没有失败也就找不到自己的不足,也就不会发现自己的问题,更不用谈改进了.我们的前辈们就是在不断的失败中才总结出了“瀑布模型”“螺旋模型”等模型,方便了我们.但是

第五章 电子星球

                   第五章         电子星球   山高高兮.路长长,岁月悠悠兮.转眼空.   镇楼竹: 1. 秀竹一枝自宛然, 莫愁风雨损华年. 几番颠扑呈贞骨, 露重霜寒节更坚. 2. 纤纤凤竹长漓边, 不共山花斗野妍. 时对清流摇倩影, 溪流常伴乐怡然. 3. 坚节何愁风雨多, 晴天朗日更婆娑. 生凉不荫趋炎客, 惹得骚人为咏歌.   咏经典物理.戏现代理论物理: 在山泉水洁如冰, 溅玉飞珠迸有声. 流入大江清浊混, 滔滔何日见澄明.     一.   批驳现代理论

深入浅出Zabbix 3.0 -- 第十五章 Zabbix 协议与API

今天是六.一儿童节,祝小朋友们节日快乐!发完此文就带我家小朋友出去玩耍了. 第十五章 Zabbix 协议与API 本章将介绍和开发相关的Zabbix协议和API的内容,通过对Zabbix协议和API的深入了解,你可以利用Zabbix协议编写客户端程序并将其嵌入的产品或系统中,并将数据发送到Zabbix server,这在无法安装Zabbixagent等程序的场景(例如专用的嵌入式系统)中非常有用.你也可以利用Zabbix API开发自己的业务系统,或灵活的与现有系统整合集成. 15.1 Zabb

Linux与云计算——第二阶段 第五章:存储Storage服务器架设—分布式存储Ceph

Linux与云计算--第二阶段Linux服务器架设 第五章:存储Storage服务器架设-分布式存储Ceph 1 Ceph 配置Ceph集群 Install Distributed File System "Ceph" to Configure Storage Cluster. For example on here, Configure Cluster with 1 admin Node and 3 Storage Node like follows. | +------------

第五章搭建S3C6410开发板的测试环境

第五章本章主要介绍开发板的调试环境的搭建,以及如何将Android系统安装开发板上. 开发板是开发和学习嵌入式技术的主要硬件设备. 尽管可以在PC上开发Linux驱动,然后重新编译成ARM构架的Linux驱动模块,但最终都是要在开发板上进行测试的. 开发板从技术上说与手机类似,包含显示器.键盘.Wi-Fi.蓝牙等模块.开发板可扩展的端口多,容易开发定制的硬件. 第一节S3V6410开发板简介 S3C6410是一款低功耗.高性价比的RISC处理器,它给予ARM11内核,可以广泛应用于移动电话和通用

第五章

第五章 搭建S3C6410开发板的测试环境 ARM构架的开发板可基于X86构架的PC 在CPU指令以及二进制格式上有所不同. 安装串口调试工具 minicon 使用OK6410开发板可以使用其他方法显示Linux驱动程序输出的调试信息.此为串口调试. OK6410开发板自带一个串口.通过串口线与PC连接,linux驱动在输出调试信息的同时,通过串口线将调试信息发送到PC上. 安装.配置和测试minicom: 1.lsmod | grep usbserial 2.apt-get install m

JS复习第五章

第五章 引用类型 一.Object类型 创建object实例的方式有两种. 第一种是使用new操作符后跟object构造函数,如下所示: ver person = new Object( ) ; person.name = “Nicholas” ; person.age = 29 ; 另一种方式是使用对象字面量表示法: var person = { name : “Nicholas”, age : 29 } ; 对象字面量是向函数传递大量可选参数的首选形式. function displayIn