杭电acm 1002 大数模板(一)
从杭电第一题开始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 大数模板(一)的更多相关文章
- 杭电ACM 1002题
import java.math.BigInteger; import java.util.Scanner; public class Main { public static void main(S ...
- 杭电ACM(1002) -- A + B Problem II 大数相加 -提交通过
杭电ACM(1002)大数相加 A + B Problem II Problem DescriptionI have a very simple problem for you. Given two ...
- 杭电ACM刷题(1):1002,A + B Problem II 标签: acmc语言 2017-05-07 15:35 139人阅读 评
最近忙于考试复习,没有多少可供自己安排的时间,所以我利用复习之余的空闲时间去刷刷杭电acm的题目,也当对自己编程能力的锻炼吧. Problem Description I have a very si ...
- 杭电ACM分类
杭电ACM分类: 1001 整数求和 水题1002 C语言实验题——两个数比较 水题1003 1.2.3.4.5... 简单题1004 渊子赛马 排序+贪心的方法归并1005 Hero In Maze ...
- 杭电ACM题单
杭电acm题目分类版本1 1002 简单的大数 1003 DP经典问题,最大连续子段和 1004 简单题 1005 找规律(循环点) 1006 感觉有点BT的题,我到现在还没过 1007 经典问题,最 ...
- 杭电acm习题分类
专注于C语言编程 C Programming Practice Problems (Programming Challenges) 杭电ACM题目分类 基础题:1000.1001.1004.1005. ...
- 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 ...
- 高手看了,感觉惨不忍睹——关于“【ACM】杭电ACM题一直WA求高手看看代码”
按 被中科大软件学院二年级研究生 HCOONa 骂为“误人子弟”之后(见:<中科大的那位,敢更不要脸点么?> ),继续“误人子弟”. 问题: 题目:(感谢 王爱学志 网友对题目给出的翻译) ...
- 杭电acm阶段之理工大版
想參加全国软件设计大赛C/C++语言组的同学,假设前一篇<C和指针课后练习题总结>没看完的,请先看完而且依照上面的训练做完,然后做以下的训练. 传送门:http://blog.csdn.n ...
随机推荐
- S3C6410开发板开发环境的搭建
本节主要介绍了S3C6410开发板及OK6410开发板.OK6410开发板是基于ARM11处理器的S3C6410,采用“核心版+底板”结构 主要步骤如下:. OK6410开发板自带一个串口,PC也需要 ...
- ThinkPHP模板中如何操作session,以及如果session中保存的是数组的情况
在ThinkPHP的模板中操作session时,可以参考ThinkPHP参考文档中的“模板—>系统变量”部分,在默认模板引擎中,语法如下: {$Think.session.user} //输出s ...
- OpenLDAP安装
参考: http://54im.com/openldap/centos-6-yum-install-openldap-phpldapadmin-tls-%E5%8F%8C%E4%B8%BB%E9%85 ...
- 打造基于CentOS7的xfce最简工作环境
参考这里:http://blog.csdn.net/smstong/article/details/44802989没成功. 又参考这里http://jensd.be/125/linux/rhel/i ...
- 读取微博feed伪代码
// 读取我的好友fids $db = new DB(); $mc = new Memcached(); $_uid = 1; // my uid $sql = "select * from ...
- python 类以及单例模式
python 也有面向对象的思想,则一切皆对象 python 中定义一个类: class student: count = 0 books = [] def __init__(self ...
- Ubuntu Install Java
http://linuxpilot.com/ubuntu-java class HelloWorld{public static void main(String[]arg){System.out.p ...
- http_load
wget http://acme.com/software/http_load/http_load-12mar2006.tar.gz
- [小菜随笔]新手使用appium+python进行自动化测试过程中webdriver.Remote报错的错误分析方法(带实例)
很多人刚开始使用python+appium去执行APP自动化的时候经常会遇到webdriver.Remote,报错位置指向都是driver = webdriver.Remote('http://127 ...
- AX2012自定义注释脚本开发
废话少说,直接进入主题: 1.在类xppSource中增加一个类似的方法: eg. Source ifElse(Source _condition = '', Source _ifStatement ...