[编程题] 大数相加

题目描述

如何实现两个非常大的数字(已经超出了Number范围)的加法运算。

注意由于这两个已经超过了Number范围,因此不能用Number存,这里我们选择使用字符串存储。

思路

我们只要将两个数字前面补0至相同的长度,然后从低位到高位进行相加, 同时用一个变量记录进位的信息即可。


值得注意的是,最后需要判断一下进位是否是0,如果不是0需要在最前面添加一个1。

参考代码

function bigNumberSum(a, b) {  	
	
  let cur = 0;	
  while (cur < a.length || cur < b.length) {	
    if (!a[cur]) {	
      a = "0" + a;	
    } else if (!b[cur]) {	
      b = "0" + b;	
    }	
    cur++;	
  }	
  let curried = 0;	
  const res = [];	
  for (let i = a.length - 1; i > -1; i--) {	
    const sum = curried + +a[i] + +b[i];	
    if (sum > 9) {	
      curried = 1;	
    } else {	
      curried = 0;	
    }	
    res[i] = sum % 10;	
  }	
  if (curried === 1) {	
    res.unshift(1);	
  }	
  return res.join("");	
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值