【算法篇】大数加法JavaScript版

46 篇文章 0 订阅
15 篇文章 1 订阅

题目描述

以字符串的形式读入两个数字,编写一个函数计算它们的和,以字符串形式返回。

数据范围:s.length,t.length≤100000,字符串仅由’0’~‘9’构成
要求:时间复杂度 𝑂(𝑛)

示例1

输入:“1”,“99”
返回值:“100”
说明:1+99=100

示例2

输入:“114514”,“”
返回值:“114514”

解题思路

为了满足时间复杂度O(n)的要求,我们可以从两个字符串的最后一位开始逐位相加,同时考虑进位的情况。以下是使用JavaScript实现的代码:

function addStrings(s, t) {
  let result = "";
  let carry = 0; // 进位初始值为0
  let i = s.length - 1; // 字符串s的索引
  let j = t.length - 1; // 字符串t的索引

  // 当两个字符串都没有遍历完或者还有进位时,继续循环
  while (i >= 0 || j >= 0 || carry > 0) {
    // 获取当前位的数字,如果索引小于0,表示字符串已经遍历完,用0代替
    const x = i >= 0 ? parseInt(s[i], 10) : 0;
    const y = j >= 0 ? parseInt(t[j], 10) : 0;

    // 计算当前位的和以及进位
    const sum = x + y + carry;
    carry = Math.floor(sum / 10); // 整除10得到进位
    result = (sum % 10) + result; // 取余数加到结果字符串前面

    // 移动索引
    i--;
    j--;
  }

  // 返回结果字符串
  return result;
}

// 示例
console.log(addStrings("1", "99")); // "100"
console.log(addStrings("114514", "")); // "114514"

以上代码的工作原理如下:

  1. 初始化一个空字符串result用于存储结果,以及一个变量carry用于存储进位值。
  2. 使用两个索引i和j分别指向字符串s和t的末尾。
  3. 当i或j大于等于0(表示至少有一个字符串还没有遍历完),或者还有进位时,执行循环体。
  4. 在循环体中,首先获取两个字符串当前位的数字,如果索引小于0,表示该字符串已经遍历完,用0代替。
  5. 计算当前位的和以及进位,将当前位的和对10取余数加到结果字符串前面,整除10得到进位值。
  6. 更新索引i和j,使它们向前移动一位。
  7. 循环结束后,返回结果字符串result。

这种方法的时间复杂度是O(max(m, n)),其中m和n分别是字符串s和t的长度。由于我们只遍历了较长的字符串的长度,所以满足了O(n)的时间复杂度要求。

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

遇见小美好

每一笔打赏都见证了你的努力💪

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

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

打赏作者

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

抵扣说明:

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

余额充值