从杭电第一题开始A,发现做到1002就不会了,经过几天时间终于A出来了,顺便整理了一下关于大数的东西

其实这是刘汝佳老师在《算法竞赛 经典入门 第二版》 中所讲的模板,代码原封不动写上的,但是经过自己的使用与调试也明白了其中的内涵。

首先定义大数的结构体:

struct BigNum{
static const int BASE=;
static const int WIDTH=;
vector<int> s;
BigNum(long long num=){ *this=num; }
BigNum operator = (long long num){
s.clear(); //vector.clear() 移除容器中的元素
do{
s.push_back(num%BASE); //vectro.push_back() 向尾部添加元素
num/=BASE;
}while(num>);
return *this;
}
BigNum operator =(const string& str){
s.clear();
int x,len=(str.length()-)/WIDTH+;
int mmm=str.length();
for(int i=;i<len;i++){
int end=str.length()-i*WIDTH;
int start=max(,end-WIDTH);
sscanf(str.substr(start,end-start).c_str(),"%d",&x);
s.push_back(x);
/*
*sscanf(str.substr(start,end-start).c_str(),"%d",&x)
*
*sscanf(a,b,c);
*三个参数 将a中的字符串以b的格式写入到c中
*
*c_str() 据说是为了和C语言兼容,并不懂,有大神知道还请讲解
*
*substr() 复制
*/
}
return *this;
}

在定义的结构体中,可以将一个大数以字符串的形式输入到结构体BigNum 中的 vector容器中,WIDTH的作用是将这个大数字符串分割成八个字符。

并且在结构体中重载了赋值运算符"="然后就可以像 BigNum a="1122334455667789891484684689" 这样对a进行赋值。

然后重载输入输出流运算符:

ostream& operator << (ostream &out,const BigNum& x){
out<<x.s.back(); //vector.back() 回传最后一个数据
for(int i=x.s.size()-;i>=;i--){
char buf[];
sprintf(buf,"%08d",x.s[i]);
for(int j=;j<strlen(buf);j++)
out<<buf[j];
/*
*sprintf(a,b,c) 把c中的b格式的数据写入到a中
*/ }
return out;
}
istream& operator >>(istream &in,BigNum& x){
string s;
if(!(in>>s)) return in;
x=s;
return in;
}

重载之后,就可以使用 cin>>a; cout<<a; 进行输入输出。

ps:buf的大小是依据题目中的数据的大小而规定的。

重载 "+":

BigNum operator +(const BigNum& b) const{
BigNum c;
c.s.clear();
for(int i=,g=;;i++){
if(g==&&i>=s.size()&&i>=b.s.size()) break;
int 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;
}

附上完整代码:

 #include <iostream>
#include <string.h>
#include <algorithm>
#include <vector>
#include <stdio.h>
using namespace std;
struct BigNum{
static const int BASE=;
static const int WIDTH=;
vector<int> s;
BigNum(long long num=){ *this=num; }
BigNum operator = (long long num){
s.clear(); //vector.clear() 移除容器中的元素
do{
s.push_back(num%BASE); //vectro.push_back() 向尾部添加元素
num/=BASE;
}while(num>);
return *this;
}
BigNum operator =(const string& str){
s.clear();
int x,len=(str.length()-)/WIDTH+;
int mmm=str.length();
for(int i=;i<len;i++){
int end=str.length()-i*WIDTH;
int start=max(,end-WIDTH);
sscanf(str.substr(start,end-start).c_str(),"%d",&x);
s.push_back(x);
/*
*sscanf(str.substr(start,end-start).c_str(),"%d",&x)
*
*sscanf(a,b,c);
*三个参数 将a中的字符串以b的格式写入到c中
*
*c_str() 据说是为了和C语言兼容,并不懂,有大神知道还请讲解
*
*substr() 复制
*/
}
return *this;
}
BigNum operator +(const BigNum& b) const{
BigNum c;
c.s.clear();
for(int i=,g=;;i++){
if(g==&&i>=s.size()&&i>=b.s.size()) break;
int 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;
}
friend ostream& operator << (ostream &out,const BigNum& x);
friend istream& operator >>(istream &in,BigNum& x);
};
ostream& operator << (ostream &out,const BigNum& x){
out<<x.s.back(); //vector.back() 回传最后一个数据
for(int i=x.s.size()-;i>=;i--){
char buf[];
sprintf(buf,"%08d",x.s[i]);
for(int j=;j<strlen(buf);j++)
out<<buf[j];
/*
*sprintf(a,b,c) 把c中的b格式的数据写入到a中
*/ }
return out;
}
istream& operator >>(istream &in,BigNum& x){
string s;
if(!(in>>s)) return in;
x=s;
return in;
}
BigNum a,b,c;
string A,B;
int main(){
int T;
cin>>T;
int flag=;
while(T--){
//cin>>A>>B;
cin>>a>>b;
//a=A;
//b=B;
c=a+b;
cout<<"Case "<<flag<<":";
cout<<endl;
//cout<<A<<" "<<"+"<<" "<<B<<" = ";
cout<<a<<" "<<"+"<<" "<<b<<" = ";
if(T!=) cout<<c<<endl;
else cout<<c;
cout<<endl;
flag++;
}
return ;
}

ps:杭电对输出格式的控制真恐怖!!!

杭电acm 1002 大数模板(一)的更多相关文章

  1. 杭电ACM 1002题

    import java.math.BigInteger; import java.util.Scanner; public class Main { public static void main(S ...

  2. 杭电ACM(1002) -- A + B Problem II 大数相加 -提交通过

    杭电ACM(1002)大数相加 A + B Problem II Problem DescriptionI have a very simple problem for you. Given two ...

  3. 杭电ACM刷题(1):1002,A + B Problem II 标签: acmc语言 2017-05-07 15:35 139人阅读 评

    最近忙于考试复习,没有多少可供自己安排的时间,所以我利用复习之余的空闲时间去刷刷杭电acm的题目,也当对自己编程能力的锻炼吧. Problem Description I have a very si ...

  4. 杭电ACM分类

    杭电ACM分类: 1001 整数求和 水题1002 C语言实验题——两个数比较 水题1003 1.2.3.4.5... 简单题1004 渊子赛马 排序+贪心的方法归并1005 Hero In Maze ...

  5. 杭电ACM题单

    杭电acm题目分类版本1 1002 简单的大数 1003 DP经典问题,最大连续子段和 1004 简单题 1005 找规律(循环点) 1006 感觉有点BT的题,我到现在还没过 1007 经典问题,最 ...

  6. 杭电acm习题分类

    专注于C语言编程 C Programming Practice Problems (Programming Challenges) 杭电ACM题目分类 基础题:1000.1001.1004.1005. ...

  7. 2017杭电ACM集训队单人排位赛 - 6

    2017杭电ACM集训队单人排位赛 - 6 排名 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 59 1 X X 1 1 X X 0 1 ...

  8. 高手看了,感觉惨不忍睹——关于“【ACM】杭电ACM题一直WA求高手看看代码”

    按 被中科大软件学院二年级研究生 HCOONa 骂为“误人子弟”之后(见:<中科大的那位,敢更不要脸点么?> ),继续“误人子弟”. 问题: 题目:(感谢 王爱学志 网友对题目给出的翻译) ...

  9. 杭电acm阶段之理工大版

    想參加全国软件设计大赛C/C++语言组的同学,假设前一篇<C和指针课后练习题总结>没看完的,请先看完而且依照上面的训练做完,然后做以下的训练. 传送门:http://blog.csdn.n ...

随机推荐

  1. Bootstrap <基础二十九>面板(Panels)

    Bootstrap 面板(Panels).面板组件用于把 DOM 组件插入到一个盒子中.创建一个基本的面板,只需要向 <div> 元素添加 class .panel 和 class .pa ...

  2. Android中Activity的启动模式

    简介 Android中的活动启动方式分为4种:standard, singleTop, singleTask, singleInstance.可以在AndroidManifest.xml中通过给< ...

  3. 讨论SEO中是锚文本有效,还是纯文本有效呢?

    现在很多SEO好友不断在讨论,在SEO优化中,到底是锚文本有效,还是纯文本有效呢? 在这里给大家举一下列子:如“张家口人才网”这样的就叫做锚文本,意思是在原有的文本中加上超级链接,指向到优化的网页上面 ...

  4. python常用的内置库

    标准库: import os os.getcwd()  //返回当前工作路径 os.chdir('/server/accesslogs')   # Change current working dir ...

  5. 手把手教你在ubuntu上安装apache和mysql和php

    1:首先安装apache:打开终端(ctrl+Alt+t), 输入命令:sudo apt-get install apache2即可安装, 安装完后,打开浏览器,在地址栏输入:localhost或者h ...

  6. ORA-06552: PL/SQL: Compilation unit analysis terminated ORA-06553: PLS-553: character set name is not recognized

    首先,确认字符集是否修改的不彻底.SELECT DISTINCT (NLS_CHARSET_NAME(CHARSETID)) CHARACTERSET,DECODE(TYPE#, 1, DECODE( ...

  7. pushlet

    自己准备做一个小游戏,租个云服务,然后挂在网上,可以跟同学一起玩,不过首先布置的是,这个游戏是否能实现,多人在线网页游戏,考虑到是否能够实时查询,在网上借鉴了下聊天原理,http长连接,搜索到push ...

  8. C++线程池

    之前一直在找一个开源的C++线程池库,找了很久也没有找到一个好用的,后来项目需要, 本想自己写一个,但是无意中在github上面找了一个采用boost库实现的threadpool,后来研究 了一下源码 ...

  9. dedecms qq咨询平均分配

    qq后台页: qq_admin.php <style type="text/css"> <!-- * {margin:0; padding:0;} .wrap { ...

  10. Linux 终端常用快捷键

    Tab 自动补全 Ctrl+L 清屏 Ctrl+A 移动到头 Ctrl+E 移动到尾 Ctrl+左键头 左移一个单词 Ctrl+右箭头 右移一个单词 Ctrl+U 删除左边所有字符 Ctrl+K 删除 ...