JS算法:大数相加

题目

给定两个字符串形式的非负整数 num1和num2 ,计算它们的和。
输入描述:

两个字符串形式的非负整数

输出描述:

对于每组测试数据,输出字符串,不包含前导零和多余空格。

输入例子:13254 4354325
输出例子:4367579

解题思路

JavaScript表达的最大整数是:pow(2, 53) = 9007199254740992。

大于2的53次方以后,多出来的有效数字(最后三位的111)都会无法保存,会变成0。

在这里插入图片描述

所以不能使用常规的加法进行计算,而且题目中输入也是两个字符串形式的整数。考虑将两字符串提取为数组,然后每位倒序相加。
在这里插入图片描述
这里应该要以位数高的为基准循环相加,当循环大于位数低的数组时,例如"5"对应的数组a2[1]是没有数字的,第二次循环时,a1[1] + a2[1] + temp实际上为9 + undefined + 上一次进位的1,如果直接相加,结果为NaN,所以将每位字符转为数字时要使用isNaN判断,如果为NaN,那么返回0。也可以在初始化数组时,将较短的数组的后几位以及较长数组的最后一位(最后结果可能进位)赋值为0。

还有就是要注意循环应该加到最高位的后一位,因为可能出现最高位相加大于10,还要进一位,95 + 5会产生三位数的结果,90 + 5会产生两位数的结果,那么给最后一位赋值为 0,最后需要根据最高位是否进位进行处理。

代码

function bigNumAdd(a, b) {
    let temp = 0,//每位相加产生的进位,初始化为0
        res = [];
    let s1 = a.split('').reverse();
    let s2 = b.split('').reverse();
    
    let format = (val) => {
        if (!isNaN(Number(val))) return Number(val)
        return 0
    }
    /* 注意此处是 i <= Math.max(s1.length, s2.length) */
    for (let i = 0; i <= Math.max(s1.length, s2.length); i++) {
        let addRes = format(s1[i]) + format(s2[i]) + temp;
        res[i] = addRes % 10;
        temp = addRes >= 10 ? 1 : 0;
    }
    res.reverse();
    /* 判断是否相加产生了进位 */
    const resultNum = res[0] > 0 ? res.join('') : res.slice(1).join('');
    return resultNum;
}

console.log(bigNumAdd('13254', '4354325'));
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小绵杨Yancy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值