相关介绍:

 在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. Mutation Observer

    MutationEvent Mutation Observer 变动观察器, 等待所有脚本任务完成后,才会运行(即异步触发方式) 把DOM变动记录封装成一个数组进行处理,而不是一条条个别处理DOM变动 ...

  2. 几种封装javaBean的方法

    开发框架时,经常需要使用java对象(javaBean)的属性来封装程序的数据,封装javaBean的方法有很多,比如反射,内省,以及使用工具类.下面从反射开始介绍. 1.javaBean介绍: 简介 ...

  3. docker 实例设置自动重启

    yaml格式太严格了,每个冒号后面都必须带有空格在linux中./代表当前目录,属于相对路径../代表上一级目录,属于相对路径/代表根目录,/开头的文件都是绝对路径./configure的意思是执行当 ...

  4. Dota2APP--第一天

    从今天开始,下定决心自己独立开发一个有关于Dota2的APP,因为非常喜欢这个游戏恰好自己又是做iOS移动开发的所以萌生了这个想法.希望可以坚持下去,有喜欢dota2的朋友也可以提点建议. 一.项目的 ...

  5. Keras2.2 predict和fit_generator的区别

    1.使用predict时,需设置batch_size 查看keras文档中,predict函数原型:predict(self, x, batch_size=32, verbose=0) 说明:只使用b ...

  6. 踩方格 OpenJ_Bailian - 4103

    有一个方格矩阵,矩阵边界在无穷远处.我们做如下假设:a.    每走一步时,只能从当前方格移动一格,走到某个相邻的方格上:b.    走过的格子立即塌陷无法再走第二次:c.    只能向北.东.西三个 ...

  7. hiho#1457 重复旋律7 求子串和 后缀自动机

    题目传送门 题意: 给出若干个串,求所有子串的和,子串和的定义为十进制数,取模1e9+7. 思路: 对于一个串来说,一个状态p就代表着$right$相同的集合,假设我们已经知道了状态p的$sum$,以 ...

  8. .NET熔断之Polly

    1. Net Core 中有一个被.Net 基金会认可的库 Polly,可以用来简化熔断降级的处理.主要功能:重试(Retry):断路器(Circuit-breaker):超时检测(Timeout): ...

  9. The Ugly Duckling

    THE UGLY DUCKLING   Chapter 1: The Ugly Duckling Hatches   A mother duck sits on many eggs.Crack! Cr ...

  10. 二、利用继承修改OPENERP 的一个模块

    问题记录1: No modules named 'xx' 原因: __init__.py 文件命名错误! 问题记录2: XMLSyntaxError: Attribute name redefined ...