当前位置: 首页 > news >正文

【算法篇】大数加法JavaScript版

题目描述

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

数据范围: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; // 进位初始值为0let 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)的时间复杂度要求。

http://www.lryc.cn/news/370561.html

相关文章:

  • 【LeetCode 128】 最长连续子序列
  • SpringCloud-面试篇(二十六)
  • 使用__try...__except和try...catch捕获异常实例分享(附源码)
  • 基于51单片机的简易温控水杯恒温杯仿真设计( proteus仿真+程序+设计报告+讲解视频)
  • 王德峰视频讲座,王德峰视频全部大全集,百度云百度网盘资源下载
  • Visual Studio和BOM历史渊源
  • 虚拟现实(VR)游戏与增强现实(AR)游戏的区别
  • git已经设置了自己的账号和密码,提交信息还是别人解决方法
  • 探索面向对象与并发编程的完美融合:Java中的实践与思考
  • 探索在线问诊系统的安全性与隐私保护
  • How To: Localize Bar and Ribbon Skin Items
  • 通过 urllib 结合代理IP下载文件实现Python爬虫
  • 单线服务器与双线服务器的区别?
  • 使用Hadoop MapReduce实现各省学生总分降序排序,根据省份分出输出到不同文件
  • LeetCode | 66.加一
  • Oracle最终会扼杀MySQL?(译)
  • 分布式物联网平台特点
  • 【学习笔记】Linux文件编译调试相关(问题未解决)
  • 微信小程序毕业设计-驾校管理系统项目开发实战(附源码+论文)
  • 【多线程】进程与线程
  • 【文献阅读】一种多波束阵列重构导航抗干扰算法
  • 前端传递bool型后端用int收不到
  • 巴伦在接收链路中的应用
  • React常见面试题(2024最新版)
  • 【万方数据库爬虫简单开发(自用)】
  • 新渠道+1!TDengine Cloud 入驻 Azure Marketplace
  • 自动化压测工具开发(MFC)
  • 【嵌入式DIY实例】-Nokia 5110显示DHT11/DHT22传感器数据
  • C# —— 字符串拼接
  • css3新增的伪类有哪些