杭电ACM(1002) -- A + B Problem II 大数相加 -提交通过
杭电ACM(1002)大数相加
A + B Problem II
Problem Description
I have a very simple problem for you. Given two integers A and B, your job is to calculate the Sum of A + B.
Input
The first line of the input contains an integer T(1<=T<=20) which means the number of test cases.
Then T lines follow, each line consists of two positive integers, A and B. Notice that the integers are very large,
that means you should not process them by using 32-bit integer. You may assume the length of each integer will not exceed 1000.
Output
For each test case, you should output two lines. The first line is "Case #:",
# means the number of the test case. The second line is the an equation "A + B = Sum",
Sum means the result of A + B. Note there are some spaces int the equation. Output a blank line between two test cases.
Sample Input
2
1 2
112233445566778899 998877665544332211
Sample Output
Case 1:
1 + 2 = 3
Case 2:
112233445566778899 + 998877665544332211 = 1111111111111111110
/*
大数相加----格式完全正确版
Problem Description
I have a very simple problem for you. Given two integers A and B, your job is to calculate the Sum of A + B.
Input
The first line of the input contains an integer T(1<=T<=20) which means the number of test cases.
Then T lines follow, each line consists of two positive integers, A and B. Notice that the integers are very large,
that means you should not process them by using 32-bit integer. You may assume the length of each integer will not exceed 1000.
Output
For each test case, you should output two lines. The first line is "Case #:",
# means the number of the test case. The second line is the an equation "A + B = Sum",
Sum means the result of A + B. Note there are some spaces int the equation. Output a blank line between two test cases.
Sample Input
2
1 2
112233445566778899 998877665544332211
Sample Output
Case 1:
1 + 2 = 3
Case 2:
112233445566778899 + 998877665544332211 = 1111111111111111110
分析,因为两数都超过了整型数的表数范围,因此在处理时,用字符数组分别来存放两个大数
然后再处理。处理时,要将数字字符和对应数字进行转换,并要考虑对应位上求和有进位的情况。
处理时要考虑几种情况
(1) 1+223 (串长度不同,不产生最高位进位)
(2) 223+1
(3) 111+222 (串长度相同,但不产生最高位进位)
(4) 1+999 (串长度不同,产生最高位进位)
(5) 999+1
(6) 199+1 (串长度不同,但不产生最高位进位)
(7) 1+199
(8) 999+222 (串长度相同,但产生最高位进位)
因此求和的数组长度一定要比两个串中较长的那个串长多1,因为要存放最高位进位
一种方法可以利用第3个数组,但为了节省空间,我们可以用第二个数组来存放求和结果
因为我们是从第二个串的最后一个位置再往后一个位置开始存放,
所以在依次求和中并不能影响还没用到的位上的数字
*/
#include <iostream>
#include <cstring>
using namespace std;
int main()
{
]; //存放第一个字符串
]; //存放第二个字符串,并存放两个串的和
int case_N; //存放case个数
int length_a; //获取第一个串的长度
int length_b; //获取第二个串的长度
char *p_a; //指向第一个串的指针
char *p_b; //指向第二个串的指针
char *p_s; //指向第二个串的指针,存放结果
int sum; //存放两个数对应位上的两个数字之和
; //存放下一次计算是否有上次的进位
int i; //循环控制变量
cin>>case_N;
;i<=case_N;i++) //用循环完成case_N次两个大数相加
{
flag=;
cout<<"Case "<<i<<":"<<endl;
cin>>a>>b;
length_a=strlen(a); //获取第一个串的长度
length_b=strlen(b); //获取第二个串的长度
p_a=a+length_a-; //指针指向第一个串的最后
p_b=b+length_b-; //指针指向第二个串的最后
cout<<a<<" + "<<b<<" = ";
p_s=b+(length_a>length_b?length_a:length_b)+; //指针指向第二个串的最后再往后两个位置,用来指向要存放的和(和要比连个两个串中的较长的那个串还多1个,因为存在进位)
*p_s='\0'; //最后一个位置放字符串结束标记
p_s--; //p_s前移
//计算求和,从各自的个位往前递增相加
while(p_a>=a&&p_b>=b) //如果两个串对应的指针都没有到各自串的第一个位置
{
sum=*p_a-'+flag; //因为是字符数组,因此要进行字符对应数字的转换,并且要加上上一次相加的进位flag(0或1)
) //对应位上数字和大于10则存在进位
{ flag=; //进位1
*p_s=sum-+'; //对应位上和减10获取对应位上数字,再转换为对应数字字符存放到数组中
}
else
{
flag=; //不进位0
*p_s=sum+';
}
p_a--;
p_b--;
p_s--;
}
) //如果第一个串中数字从地位到高位都加完了
{
while(p_b>=b) //则循环加第二个串中剩下没加的数字,加到字符串的第一个数字字符
{
sum=*p_b-'+flag;
)
{ flag=;
*p_s=sum-+';
}
else
{
flag=;
*p_s=sum+';
}
p_b--;
p_s--;
}
}
else //如果第二个串中数字从地位到高位都加完了
{
while(p_a>=a) //则循环加第二个串中剩下没加的数字,加到字符串的第一个数字字符
{
sum=*p_a-'+flag;
)
{ flag=;
*p_s=sum-+';
}
else
{
flag=;
*p_s=sum+';
}
p_a--;
p_s--;
}
}
) //如果最后一次相加无进位
cout<<p_s+; //从第二个数组中的第二个位置开始输出,即为求和结果
else //如果最后一次相加有进位,则把进位1,存放到第二个数组中的第一个位置
{
*p_s='; //则把进位'1',存放到第二个数组中的第一个位置
cout<<p_s; //从第二个数组中的第一个位置开始输出,,即为求和结果
}
if(i==case_N)
cout<<endl;
else
cout<<endl<<endl; //两个case之间有空行隔开
}
;
}

以下程序是就完成一次两个大数相加
#include <iostream>
#include <cstring>
using namespace std;
int main()
{
]; //存放第一个字符串
]; //存放第二个字符串,并存放两个串的和
int sum; //存放两个数对应位上的两个数字之和
; //存放下一次计算是否有上次的进位
cin>>a>>b;
int length_a=strlen(a); //获取第一个串的长度
int length_b=strlen(b); //获取第二个串的长度
; //指针指向第一个串的最后
; //指针指向第二个串的最后
cout<<a<<" + "<<b<<" = ";
; //指针指向第二个串的最后再往后两个位置,用来指向要存放的和(和要比连个两个串中的较长的那个串还多1个,因为存在进位)
*p_s='\0'; //最后一个位置放字符串结束标记
p_s--; //p_s前移
//计算求和,从各自的个位往前递增相加
while(p_a>=a&&p_b>=b) //如果两个串对应的指针都没有到各自串的第一个位置
{
sum=*p_a-'+flag; //因为是字符数组,因此要进行字符对应数字的转换,并且要加上上一次相加的进位flag(0或1)
) //对应位上数字和大于10则存在进位
{ flag=; //进位1
*p_s=sum-+'; //对应位上和减10获取对应位上数字,再转换为对应数字字符存放到数组中
}
else
{
flag=; //不进位0
*p_s=sum+';
}
p_a--;
p_b--;
p_s--;
}
) //如果第一个串中数字从地位到高位都加完了
{
while(p_b>=b) //则循环加第二个串中剩下没加的数字,加到字符串的第一个数字字符
{
sum=*p_b-'+flag;
)
{ flag=;
*p_s=sum-+';
}
else
{
flag=;
*p_s=sum+';
}
p_b--;
p_s--;
}
}
else //如果第二个串中数字从地位到高位都加完了
{
while(p_a>=a) //则循环加第二个串中剩下没加的数字,加到字符串的第一个数字字符
{
sum=*p_a-'+flag;
)
{ flag=;
*p_s=sum-+';
}
else
{
flag=;
*p_s=sum+';
}
p_a--;
p_s--;
}
}
) //如果最后一次相加无进位
cout<<p_s+<<endl; //从第二个数组中的第二个位置开始输出,即为求和结果
else //如果最后一次相加有进位,则把进位1,存放到第二个数组中的第一个位置
{
*p_s='; //则把进位'1',存放到第二个数组中的第一个位置
cout<<p_s<<endl; //从第二个数组中的第一个位置开始输出,,即为求和结果
}
;
}
以下程序用了三个数组实现一次两个大数相加
#include <iostream>
#include <cstring>
using namespace std;
int main()
{
];
];
]={'\0'};
int sum;
;
cin>>a>>b;
cout<<a<<" + "<<b<<" = ";
int length_a=strlen(a);
int length_b=strlen(b);
;
;
char *p_s=s+(length_a>length_b?length_a:length_b);
while(p_a>=a&&p_b>=b)
{
sum=*p_a-'+flag;
)
{ flag=;
*p_s=sum-+';
}
else
{
flag=;
*p_s=sum+';
}
p_a--;
p_b--;
p_s--;
}
)
{
)
{
sum=*p_b-'+flag;
)
{ flag=;
*p_s=sum-+';
}
else
{
flag=;
*p_s=sum+';
}
p_b--;
p_s--;
}
}
else
{
)
{
sum=*p_a-'+flag;
)
{ flag=;
*p_s=sum-+';
}
else
{
flag=;
*p_s=sum+';
}
p_a--;
p_s--;
}
}
)
cout<<p_s+<<endl;
else
{
*p_s=';
cout<<p_s<<endl;
}
;
}
杭电ACM(1002) -- A + B Problem II 大数相加 -提交通过的更多相关文章
- 杭电acm 1002 大数模板(一)
从杭电第一题开始A,发现做到1002就不会了,经过几天时间终于A出来了,顺便整理了一下关于大数的东西 其实这是刘汝佳老师在<算法竞赛 经典入门 第二版> 中所讲的模板,代码原封不动写上的, ...
- 杭电ACM 1002题
import java.math.BigInteger; import java.util.Scanner; public class Main { public static void main(S ...
- 杭电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 经典问题,最 ...
- HDU 1002 A + B Problem II(高精度加法(C++/Java))
A + B Problem II Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- 杭电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 ...
- 抓起根本(二)(hdu 4554 叛逆的小明 hdu 1002 A + B Problem II,数字的转化(反转),大数的加法......)
数字的反转: 就是将数字倒着存下来而已.(*^__^*) 嘻嘻…… 大致思路:将数字一位一位取出来,存在一个数组里面,然后再将其变成数字,输出. 详见代码. while (a) //将每位数字取出来, ...
随机推荐
- (转)实战Memcached缓存系统(8)Memcached异步实时读写问题的解决方案SAC
在使用Memcached时,一般实时读写的场景并不多见.但多是Memcached写入后,在一定时间后才会有读操作.但是如果应用场景,是写入后瞬间即会有读操作呢?似乎没有什么特别之处,我们依然可以这样写 ...
- Javascript中的函数
Javascript中的函数 1.什么是函数 函数是被命名的,独立的,完成特定功能的代码段.其可能给调用它的程序返回值,我们把这个代码段就称之为"函数". 被命名的:函数大部分都是 ...
- 十天学会零基础入门学习Photoshop课程(在线观看)
适合人群:在校学生 在职工作者 淘宝运营者等一系列会操作电脑的人群 课程目录 试学课 课时11前言 8分钟1秒 课时22工作界面 试学课 课时33文件的新建 试学课 课时44文档保存 11分钟24秒 ...
- Mac OS X开发者准备工作
迁移到Mac平台做开发后,需要有一系列的准备工作来使我们的工作更顺畅. 1. 安装Homebrew包管理器 苹果系统自带了一个包管理器,但是并不是很好用.现在,现在比较流行的是Homebrew,非常好 ...
- 在Spring中使用cache(EhCache的对象缓存和页面缓存)
Spring框架从version3.1开始支持cache,并在version4.1版本中对cache功能进行了增强. spring cache 的关键原理就是 spring AOP,通过 spring ...
- 如何使用C#操作快捷方式(获取快捷方式属性、创建快捷方式)
近来项目中有需要用到一个技术:使用C#操控快捷方式,包含创建和读取等.现整理一下实现方式,分享给大家. 第一步 创建一个项目 无需废话,跳过. 第二步 引用COM组件 右键“引用”,“添加引用”, ...
- jdbc之分页查询
分页查询作为一项十分重要的数据库查询技术,在很多web项目中都会要用到,当然移动开发中也是会涉及的. 一.分页查询的sql语句: ps:为了方便阐述,下面统一使用student表作为查询的表:colN ...
- 在SAE上同步djanogo的mysql数据库
折腾了一个下午,终于搞掂了把djanogo应用的mysql数据库导入到SAE上了,归根到底麻烦的根源是SAE限制多多.下面简单记录一下过程以备日后参考使用. 首先还是修改settings.py,把数据 ...
- Torry的困惑(基本型)
#include<stdio.h> int main() { long long i,j; int n; //用于记录输入的要进行乘积的质数的个数 ; //用于记录前n个质数的乘积,并初始 ...
- ISBN
问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如“x-xxx-xxxxx-x”,其中符号“-”是分隔符(键盘上的减号),最后一位 ...