相关介绍:

 在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为例进行加法的计算过程。

对于两个大数的加法,其操作步骤归纳如下:

  1. 将两个加数的相应位从高位到低位依次压入栈sA和sB中。
  2. 若两个加数栈都非空,则依次从栈中弹出栈顶数字相加,和存入变量partialSum中,若和有进位,则将和的个位数压入结果栈sum中,并将进位数加到下一位数字相加的和中,若和没有进位,则直接将和压入结果栈sum中
  3. 若某个加数堆栈为空,则将非空加数栈中的栈顶数字依次弹出与进位相加,和的个位数压入结果栈sum中,直到此该栈为空为止,若最高位有进位,则最后将1压入栈sum中
  4. 若两个加数栈都为空,则栈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:大数加法的更多相关文章

  1. 51nod 1005 大数加法

    #include<iostream> #include<string> using namespace std; #define MAXN 10001 },b[MAXN]={} ...

  2. vector、string实现大数加法乘法

    理解 vector 是一个容器,是一个数据集,里边装了很多个元素.与数组最大的不同是 vector 可以动态增长. 用 vector 实现大数运算的关键是,以 string 的方式读入一个大数,然后将 ...

  3. hdu_1041(Computer Transformation) 大数加法模板+找规律

    Computer Transformation Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/ ...

  4. Hat's Fibonacci(大数加法+直接暴力)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1250 hdu1250: Hat's Fibonacci Time Limit: 2000/1000 M ...

  5. A + B Problem II(大数加法)

    http://acm.hdu.edu.cn/showproblem.php?pid=1002 A + B Problem II Time Limit: 2000/1000 MS (Java/Other ...

  6. 【BZOJ3110】K大数查询(整体二分)

    [BZOJ3110]K大数查询(整体二分) 题面 BZOJ 题解 看了很久整体二分 一直不知道哪里写错了 ... 又把树状数组当成线段树区间加法来用了.. 整体二分还是要想清楚在干什么: 我们考虑第\ ...

  7. 大数加法~HDU 1002 A + B Problem II

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1002 题意: 数学题,A+B; 思路,这个数非常大,普通加法一定会超时,所以用大数加法.大数加法的基 ...

  8. ZZNU 2125:A + B 普拉斯(傻逼题+大数加法)

    2125: A + B 普拉斯 时间限制: 1 Sec  内存限制: 128 MB 提交: 94  解决: 28 [提交] [状态] [讨论版] [命题人:admin] 题目描述 "别人总说 ...

  9. poj3535 A+B (大数加法)

    A+B Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 811   Accepted: 371 Description The ...

  10. HDU——1715大菲波数(大数加法)

    大菲波数 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submi ...

随机推荐

  1. spring-boot打包,引入外部jar包问题

    这是我引入的外部jar包,打包的时候找不到外部jar包路径 弄了好久 在lib下引入外部jar包,运行没问题,但是打包是出现问题了,具体解决办法 再pom中加入如下配置,告诉maven导入本地jar ...

  2. 《条目二十九:对于逐个字符的输入请考虑istreambuf_iterator》

    <条目二十九:对于逐个字符的输入请考虑istreambuf_iterator> 1.使用: ifstream inputfile("xxxx"); string fil ...

  3. 网络请求及各类错误代码含义总结(包含AFN错误码大全)

    碰见一个很奇葩的问题, 某些手机在设置了不知什么后, 某些 APP 死活 HTTPS 请求失败, 例如以 UMeng 统计HTTP 请求失败为例, Log如下: UMLOG: (Error   App ...

  4. 2016级算法期末上机-H.难题·AlvinZH's Fight with DDLs III

    1119 AlvinZH's Fight with DDLs III 思路 难题,最小点覆盖. 分析题意,某一个任务,既可以在笔记本A的 \(a\) 模式下完成,也可以在笔记本B的 \(b\) 模式下 ...

  5. servlet,listener,filter,interceptor的关系

    1.servlet:servlet是一种运行服务器端的java应用程序,具有独立于平台和协议的特性,并且可以动态的生成web页面,它工作在客户端请求与服务器响应的中间层.最早支持 Servlet 技术 ...

  6. 并发编程>>四种实现方式(三)

    概述 1.继承Thread 2.实现Runable接口 3.实现Callable接口通过FutureTask包装器来创建Thread线程 4.通过Executor框架实现多线程的结构化,即线程池实现. ...

  7. JavaIO流总结

    字节流 InputStream FileInputStream FilterInputStream BufferedInputStream DataInputStream PushbackInputS ...

  8. Homebrew下安装的软件自启动服务管理工具:Launchrocket

    帮助管理Homebrew安装的服务的软件,比如使用Homebrew安装的Mysql.Redis.MongoDB,传统方式需要使用命令行的命令,而使用LaunchRocket则可以在图形界面中进行管理. ...

  9. IT人生的价值和意义 感觉真的有了

     为了做新闻APP,我居然短短一个月利用业余时间做了: 一个通用新闻采集器. 一个新闻后台审核网站. 一个通用采集器下载网站. 一个新闻微网站. 一个新闻APP, 而且还给新闻微网站和新闻 APP练就 ...

  10. kafka多线程消费topic的问题

    案例: topic:my-topic,分区:6 消费者:部署三台机器,每台机器上面开启6个线程消费. 消费结果:只有一台机器可以正常消费,另外两台机器直接输出六条告警日志: No broker par ...