题目:http://acm.hdu.edu.cn/showproblem.php?pid=1002

题目提示,相加的两个数的位数可能很大(最多可达1000位),而int最多32位,long long类型和__int64类型都是最多64位,均不能存储位数过多的数,所以现有的数据类型无法直接存储.

思路:用字符串存储输入的数字,模拟加法的过程,即相加和进位的过程.

首先,来看一下,加法以及进位的原理,以便后面[核心代码]的理解.

No.1   6 + 7 = 13——>1和3,第一位写3,进位为1

No.2   8 + 3 = 11——>11 + No.1中的进位1 = 12——>1和2,第二位写2,进位为1

No.3   9 + 0 = 9——>9 + No.2中的进位1 = 10——>1和0,第三位写0,进位为1

No.4   7 + 4 = 11——>11 + No.3中的进位1 = 12——>1和2,第四位写2,进位为1

No.5   0 + 0 = 0——>0 + No.4中的进位1 = 1——>0和1,第五为写1,没有进位,结束

由于两数的第一位没有进位可以加,所以直接是对应的两数相加,取余数就是3.从第二位开始,对应数加完之后,还要与前面的的进位的数(1或者0)相加,再取余数,才是这一位的数.

下面思考,如何写代码?

1.用字符串(string类对象)表示输入的数.

2.给定输入的两个数x和y(用string类型x和y存储),应该作如下处理

图示做了两个方面处理,(1)对齐,方便对应位置的数字进行加法运算.(2)在最前面还加了一个0,给可能存在的进位预留一个位置,例如99+1,结果的位数为3位.

3.在进行加法的时候,逆序(从低位开始)进行.

C++代码如下

#include<iostream>
#include<string>
using namespace std; #define max(a,b) (a>b?a:b)//类似于定义一个函数求二者中的较大者 int main()
{
//freopen("in.txt","r",stdin);//调试用
int T;
cin >> T;//T组数据
for(int t=1;t<=T;t++)
{
string x,y;
cin >> x >> y;//输入两个数 //结果输出时的格式控制
cout << "Case " << t << ":" << endl;
cout << x << " + " << y << " = "; int xL = x.length();//x的长度
int yL = y.length();//y的长度 if(xL<yL)//如果x的位数小,则交换,因为最后统一将结果存储在x中
{
x.swap(y);//交换内容 int len = xL;//因为后面要用到yL,所以长度也要交换
xL = yL;
yL = len;
} //到这里x一定是长度较长的那个 int L = max(xL,yL) + 1;//结果的长度为x和y的最大长度+1(此处L的值其实就是xL+1) x = '0' + x;//x的前面添加一个0 int i,j;//循环变量 for(i=yL+1;i<=L;i++)//使x和y的长度一样
y = '0' + y;//添加0 //下面开始加法运算了
int c = 0;//记录进位:c=1或者c=0
for(i=L-1;i>=0;i--)//从右边加到左边
{
int z = x[i]-'0';//获取x[i]对应的字符对应的数字,例如x[i] = '6',则x[i]-'0'就是int型的6.
int w = y[i]-'0';
int h = z + w + c;//下面三行代码是[核心代码],描述加法的过程
c = h / 10;
x[i] = h%10 + '0';
} //输出预处理:找到从什么开始没有0(去除前导0)
for(i=0;i<L;i++)
if(x[i]!='0')
break;
for(j=i;j<L;j++)//输出
cout << x[j];
cout << endl; if(t!=T)//空行
cout << endl;
} return 0;
}

上述代码,提交可以通过.

小结:

1.调试小技巧:在主函数开始写 freopen("in.txt","r",stdin);     其中in.txt为cpp文件同目录下的输入数据.

2.宏定义的使用:#define max(a,b) (a>b?a:b)   不需要写数据类型

【hdoj_1002】A+B Problem ||(大数)的更多相关文章

  1. A+B and A*B problem 大数相加 相乘 模拟

    A+B and A*B problem 大数相加 相乘 模拟 题意 给你两个数a和b,这两个数很大,然后输出这两个数相加的和,相乘的积. 解题思路 模拟,但是还是搜了搜代码实现,发现这个大佬写的是真的 ...

  2. 快速切题 sgu 111.Very simple problem 大数 开平方 难度:0 非java:1

    111.Very simple problem time limit per test: 0.5 sec. memory limit per test: 4096 KB You are given n ...

  3. 1051:A × B problem 大数相乘

    给你两个整数,请你计算A × B. 输入 数据的第一行是整数T(1 ≤ T ≤ 20),代表测试数据的组数.接着有T组数据,每组数据只有一行,包括两个非负整数A和B.但A和B非常大,Redraimen ...

  4. A water problem 大数取余。

    A water problem Time Limit: 5000/2500 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)T ...

  5. sdut2613(This is an A+B Problem)大数加法(乘法)

    #include <iostream>#include <stdio.h>#include <string.h>#include <stdlib.h>u ...

  6. 2016中国大学生程序设计竞赛(长春) Ugly Problem 模拟+大数减法

    传送门:http://acm.hdu.edu.cn/showproblem.php?pid=5920 我们的思路是: 对于一个串s,先根据s串前一半复制到后一半构成一个回文串, 如果这个回文串比s小, ...

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

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

  8. HDOJ/HDU 5686 Problem B(斐波拉契+大数~)

    Problem Description 度熊面前有一个全是由1构成的字符串,被称为全1序列.你可以合并任意相邻的两个1,从而形成一个新的序列.对于给定的一个全1序列,请计算根据以上方法,可以构成多少种 ...

  9. Train Problem II(卡特兰数+大数乘除)

    Train Problem II Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

随机推荐

  1. 最小生成树-----Prim算法与Kruskal算法(未完

    生成树(spanning tree):无向联通图的某个子图中,任意两个顶点互相都联通并且形成了一棵树,那么这棵树就叫做生成树. 最小生成树(MST,minimum spanning tree):如果为 ...

  2. 解题:SCOI 2014 方伯伯运椰子

    题面 很有趣的一道题,看起来是个神奇网络流,其实我们只要知道网络的一些性质就可以做这道题了 因为题目要求流量守恒,所以我们其实是在网络中搬运流量,最终使得总费用减小,具体来说我们可以直接把这种“搬运” ...

  3. [知识点]C++中STL容器之vector

    零.STL目录 1.容器之map 2.容器之vector 3.容器之set 一.前言 关于STL和STL容器的概念参见STL系列第一篇——map(见上).今天介绍第二个成员——vector. 二.用途 ...

  4. CDOJ--1404

    原题链接:http://acm.uestc.edu.cn/problem.php?pid=1404 分析:定义dp[i][j]表示i位时最左边为j时的情况,那么dp[i][[j]可以由dp[i-1][ ...

  5. 由保存当前用户引发的springboot的测试方式postman/restlet还是swagger2

    今天在测试接口的到时候发现用springboot集成swagger2集成的项目,在测试session保存的当前用户的时候,发现执行不了,没有像postman或者restlet一样,保存这个接口的url ...

  6. 数据分析与展示---anaconda的使用

    一:安装 官方源:https://repo.continuum.io/archive/(太慢) 清华源:https://mirrors.tuna.tsinghua.edu.cn/anaconda/ar ...

  7. AngularJs附件上传下载

    首先:angular-file-upload 是一款轻量级的 AngularJS 文件上传工具,为不支持浏览器的 FileAPI polyfill 设计,使用 HTML5 直接进行文件上传. 第一步: ...

  8. Python学习笔记(九)返回函数

    摘抄:https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/0014318352367 ...

  9. 【BZOJ】1778: [Usaco2010 Hol]Dotp 驱逐猪猡

    [题意]给定无向图,炸弹开始在1,在每个点爆炸概率Q=p/q,不爆炸则等概率往邻点走,求在每个点爆炸的概率.n<=300. [算法]概率+高斯消元 [题解]很直接的会考虑假设每个点爆炸的概率,无 ...

  10. 【LibreOJ】#6257. 「CodePlus 2017 12 月赛」可做题2

    [题意]数列满足an=an-1+an-2,n>=3.现在a1=i,a2=[l,r],要求满足ak%p=m的整数a2有多少个.10^18. [算法]数论(扩欧)+矩阵快速幂 [题解]定义fib(i ...