K:大数加法
相关介绍:
在java中,整数是有最大上限的。所谓大数是指超过整数最大上限的数,例如18 452 543 389 943 209 789 324 233和8 123 534 323 432 323 432 123 212 443就是两个大数,在java中这是无法用整型int变量或长整型long变量来进行保存的,更不用说保存他们之间相加的和了。为解决该问题,可以把两个相加数看成是字符串,将这些数的相应数字存储在两个堆栈中,并从两个栈中弹出对应位的数字依次执行加法可得到结果,以784和8465为例进行加法的计算过程。

对于两个大数的加法,其操作步骤归纳如下:
- 将两个加数的相应位从高位到低位依次压入栈sA和sB中。
- 若两个加数栈都非空,则依次从栈中弹出栈顶数字相加,和存入变量partialSum中,若和有进位,则将和的个位数压入结果栈sum中,并将进位数加到下一位数字相加的和中,若和没有进位,则直接将和压入结果栈sum中
- 若某个加数堆栈为空,则将非空加数栈中的栈顶数字依次弹出与进位相加,和的个位数压入结果栈sum中,直到此该栈为空为止,若最高位有进位,则最后将1压入栈sum中
- 若两个加数栈都为空,则栈sum中保存的就是计算结果。注意栈顶是所得计算结果的最高位
其代码如下:
package queueandstack;
import java.util.Stack;
/**
* 该类用于演示大数加法的相关代码
* @author 学徒
*
*/
public class BigNumberAdd
{
/**
* 求两个大数的和,加数与被加数以字符串的形式输入(允许大数中出现空格),计算的结果也以字符串的形式返回
*/
public String add(String number1,String number2)throws Exception
{
Stack result=new Stack();//大数的和
Stack number1Stack=numberSplit(number1);//加数字符串以单个字符的形式放入栈中
Stack number2Stack=numberSplit(number2);//被加数字符串以单个字符的形式放入栈中
int partialSum;//对于两个位的求和
boolean isCarry=false;//进位标志
while(!number1Stack.isEmpty()&&!number2Stack.isEmpty())//加数和被加数栈同时非空
{
partialSum=(Integer)number1Stack.pop()+(Integer)number2Stack.pop();//对于两个位进行求和,并在栈中去除掉加数和被加数中的该位
//当有低位的进位时
if(isCarry)
{
partialSum++;
isCarry=false;
}
//需要进行进位
if(partialSum>=10)
{
partialSum-=10;
isCarry=true;
}
//将本位的结果放入结果栈中
result.push(partialSum);
}
Stack temp=!number1Stack.isEmpty()?number1Stack:number2Stack;//将temp引用指向加数和被加数中非空栈
while(!temp.isEmpty())
{
//当最后一次加法运算中存在进位的时候
if(isCarry)
{
int t=(Integer)temp.pop();//取出其中的加数或者被加数中没有参加的位
++t;//进位加到此位上
if(t>=10)//当其需要进行进位的时候
{
t-=10;
}
else//重置其进位标志
{
isCarry=false;
}
result.push(t);
}
else//最后一次执行加法运算中不需要进位
{
result.push(temp.pop());//把加数或者被加数中非空的值放入和中
}
}
if(isCarry)//将最高位加入到结果中
{
result.push(1);
}
String resultstr=new String();
while(!result.isEmpty())
{
//把栈中的元素转化为字符串
resultstr=resultstr.concat(result.pop().toString());
}
return resultstr;
}
/**
* 该方法用于将输入的大数拆分成单个的字符,并去掉字符串中的空格,返回以单个字符为元素的栈
*
*/
public Stack numberSplit(String str)throws Exception
{
Stack result=new Stack();
for(int i=0;i<str.length();i++)
{
char c=str.charAt(i);//指定索引处的char值
if(' '==c)//去除掉空格
continue;
else if('0'<=c&&'9'>=c)//将数字放入栈中
result.push(Integer.valueOf(String.valueOf(c)));
else
throw new Exception("错误:输入了非数字型的字符!");
}
return result;
}
/**
* 用于测试程序
*/
public static void main(String[] args)throws Exception
{
BigNumberAdd a=new BigNumberAdd();
System.out.println("两个大数为:");
System.out.println("1. 18 452 543 389 943 209 752 345 473");
System.out.println("2. 8 123 542 678 432 986 899 334");
System.out.println("其和为:");
System.out.println(a.add("18 452 543 389 943 209 752 345 473", "8 123 542 678 432 986 899 334"));
}
}
运行结果:
两个大数为:
1. 18 452 543 389 943 209 752 345 473
2. 8 123 542 678 432 986 899 334
其和为:
18460666932621642739244807
K:大数加法的更多相关文章
- 51nod 1005 大数加法
#include<iostream> #include<string> using namespace std; #define MAXN 10001 },b[MAXN]={} ...
- vector、string实现大数加法乘法
理解 vector 是一个容器,是一个数据集,里边装了很多个元素.与数组最大的不同是 vector 可以动态增长. 用 vector 实现大数运算的关键是,以 string 的方式读入一个大数,然后将 ...
- hdu_1041(Computer Transformation) 大数加法模板+找规律
Computer Transformation Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/ ...
- Hat's Fibonacci(大数加法+直接暴力)
题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1250 hdu1250: Hat's Fibonacci Time Limit: 2000/1000 M ...
- A + B Problem II(大数加法)
http://acm.hdu.edu.cn/showproblem.php?pid=1002 A + B Problem II Time Limit: 2000/1000 MS (Java/Other ...
- 【BZOJ3110】K大数查询(整体二分)
[BZOJ3110]K大数查询(整体二分) 题面 BZOJ 题解 看了很久整体二分 一直不知道哪里写错了 ... 又把树状数组当成线段树区间加法来用了.. 整体二分还是要想清楚在干什么: 我们考虑第\ ...
- 大数加法~HDU 1002 A + B Problem II
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1002 题意: 数学题,A+B; 思路,这个数非常大,普通加法一定会超时,所以用大数加法.大数加法的基 ...
- ZZNU 2125:A + B 普拉斯(傻逼题+大数加法)
2125: A + B 普拉斯 时间限制: 1 Sec 内存限制: 128 MB 提交: 94 解决: 28 [提交] [状态] [讨论版] [命题人:admin] 题目描述 "别人总说 ...
- poj3535 A+B (大数加法)
A+B Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 811 Accepted: 371 Description The ...
- HDU——1715大菲波数(大数加法)
大菲波数 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
随机推荐
- spring-boot打包,引入外部jar包问题
这是我引入的外部jar包,打包的时候找不到外部jar包路径 弄了好久 在lib下引入外部jar包,运行没问题,但是打包是出现问题了,具体解决办法 再pom中加入如下配置,告诉maven导入本地jar ...
- 《条目二十九:对于逐个字符的输入请考虑istreambuf_iterator》
<条目二十九:对于逐个字符的输入请考虑istreambuf_iterator> 1.使用: ifstream inputfile("xxxx"); string fil ...
- 网络请求及各类错误代码含义总结(包含AFN错误码大全)
碰见一个很奇葩的问题, 某些手机在设置了不知什么后, 某些 APP 死活 HTTPS 请求失败, 例如以 UMeng 统计HTTP 请求失败为例, Log如下: UMLOG: (Error App ...
- 2016级算法期末上机-H.难题·AlvinZH's Fight with DDLs III
1119 AlvinZH's Fight with DDLs III 思路 难题,最小点覆盖. 分析题意,某一个任务,既可以在笔记本A的 \(a\) 模式下完成,也可以在笔记本B的 \(b\) 模式下 ...
- servlet,listener,filter,interceptor的关系
1.servlet:servlet是一种运行服务器端的java应用程序,具有独立于平台和协议的特性,并且可以动态的生成web页面,它工作在客户端请求与服务器响应的中间层.最早支持 Servlet 技术 ...
- 并发编程>>四种实现方式(三)
概述 1.继承Thread 2.实现Runable接口 3.实现Callable接口通过FutureTask包装器来创建Thread线程 4.通过Executor框架实现多线程的结构化,即线程池实现. ...
- JavaIO流总结
字节流 InputStream FileInputStream FilterInputStream BufferedInputStream DataInputStream PushbackInputS ...
- Homebrew下安装的软件自启动服务管理工具:Launchrocket
帮助管理Homebrew安装的服务的软件,比如使用Homebrew安装的Mysql.Redis.MongoDB,传统方式需要使用命令行的命令,而使用LaunchRocket则可以在图形界面中进行管理. ...
- IT人生的价值和意义 感觉真的有了
为了做新闻APP,我居然短短一个月利用业余时间做了: 一个通用新闻采集器. 一个新闻后台审核网站. 一个通用采集器下载网站. 一个新闻微网站. 一个新闻APP, 而且还给新闻微网站和新闻 APP练就 ...
- kafka多线程消费topic的问题
案例: topic:my-topic,分区:6 消费者:部署三台机器,每台机器上面开启6个线程消费. 消费结果:只有一台机器可以正常消费,另外两台机器直接输出六条告警日志: No broker par ...