Java面试 两个大字符串数字相加

https://www.cnblogs.com/socrates-lzstu/p/6774682.html
转载自此博客,感谢博主的分享!
昨天面试遇到的,挂了,今天自己网上查了一下,理解下怎么实现的,写成博客也不至于过两个月就忘了,也是算给自己一个警醒。

题大概是这样的:
有两个字符串数字,数字特别大,数字超出了Integer相加的范围,类似于
String a1 = “1615146841218….1234”;
String a2 = “8675446841218….4321”;
直接相加的会有溢出,写一个算法实现相加:
我们直接计算是不行的,需要每一位字符一个一个相加,相加之后在一位一位添加到一个新字符串中,但是如果说两个大于5的数值相加,就会溢出一位,相应的上一位就应该加1,所以说我们需要将两个字符串反转,从小到大一个一个的加,溢出之后,在进位上加1。
假设这个字符串是99999和123,倒序排序之后为99999,321,将小的字符串长度补齐, 为99999,32100,第一次遍历, 9 + 3 为12 ,即个位数为2 ,十位数进一位,我们就需要将1 提出来,在下一次遍历时加上,即现在新字符串值为2,进一位有个1;第二次遍历,9+2 = 11,新字符串值为‘2 ’+ ‘(1 + 1)’,又有一个进位1…依此类推

        StringBuffer s1 = new StringBuffer(str1).reverse();
        StringBuffer s2 = new StringBuffer(str2).reverse();
        StringBuffer res = new StringBuffer();

        int len1 = s1.length();
        int len2 = s2.length();
        int len;

        if (len1 < len2) {
            len = len2;
            int count = len2 - len1;
            while (count-- > 0)
                s1.append('0');
        } else {
            len = len1;
            int count = len1 - len2;
            while (count-- > 0)
                s2.append('0');
        }

        int overflow = 0; 
        int num;

        for (int i = 0; i < len; i++) {
            num = s1.charAt(i) - '0' + s2.charAt(i) - '0' + overflow;
            if (num >= 10) {
                overflow = 1;
                num -= 10;
            } else {
                overflow = 0;
            }
            res.append(String.valueOf(num));
        }

        if (overflow == 1)
            res.append(1);

        return res.reverse().toString();

这个算法的时间复杂度是O(n),空间复杂度是O(1),还有可以使用BigInteger类直接计算。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值