从零开始刷力扣(六十七)——415. 字符串相加

分类:字符串

题目描述

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

提示:

  1. num1 和num2 的长度都小于 5100
  2. num1 和num2 都只包含数字 0-9
  3. num1 和num2 都不包含任何前导零
  4. 你不能使用任何內建 BigInteger 库, 也不能直接将输入的字符串转换为整数形式

思路:

将位数较小的字符串前置补0,然后从后往前做加法,大于10进位;

代码实现:

/**
 * @param {string} num1
 * @param {string} num2
 * @return {string}
 */
var addStrings = function (num1, num2) {
    const len1 = num1.length;
    const len2 = num2.length;
    const maxLength = Math.max(len1, len2);
    len1 < len2 ? num1 = num1.padStart(maxLength, '0') : num2 = num2.padStart(maxLength, '0');
    let sum = 0;
    let result = [];
    for (let i = maxLength - 1; i > 0; i--) {
        sum = (num1[i] - 0) + (num2[i] - 0) + (result[i] || 0);
        if (sum < 10) {
            result[i] = sum;
        } else {
            result[i] = sum % 10;
            result[i - 1] = 1;
        }
    }
    sum = (num1[0] - 0) + (num2[0] - 0) + (result[0] || 0);
    if (sum < 10) {
        result[0] = sum;
    } else {
        result[0] = sum % 10;
        result.unshift(1);
    }
    return result.join('');
};

运行结果:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值