java利用链栈实现大数加法问题

本文通过链栈解决大数加法问题,步骤包括将加数按位压栈、逐位相加处理进位、处理非空栈和进位、直至所有栈为空得到结果。核心是利用链栈的数据结构进行计算。
摘要由CSDN通过智能技术生成

【问题分析】

1、将两个加数的相应位从高位到低位依次压如栈sa,sb

2、若两个加数栈都非空,则依次从栈中弹出栈顶数字相加,结果存入partialsum;

     若和有进位,则将和的个位数压入结果栈sum中,并将进位数1加到下一位数字相加的和中;

       若和没有进位,则直接将和存入栈sum中

3、若某个加数堆栈为空,则将非空栈中的站顶数字依次弹出与进位数相加,和的个位数压入sum,直到该栈为空为止。

    若最高位有进位,则最后将1压入sum

4、若两个加数栈都为空,则栈sum中保存的就是计算结果。栈顶是结果中最高位数字。


链栈中的结点类就是前面文章的Node类,不再重复

下面是实现栈的抽象数据类型用java接口描述

public interface Istack {
	public void clear();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值