我倒在了美团面试算法题:字符串大数相加

我倒在了美团面试算法题:字符串大数相加

话说之前换工作的时候,我经历了一次美团的视频面试。

不像腾讯面试有自家软件,美团面试是在第三方网页上进行的,长这样:


<span>我倒在了美团面试算法题:字符串大数相加</span>

看见中间的代码编辑区,我笑了,难道?真的?算法?

我的算法,有点差呀。而且没怎么刷过题。

默默祈祷不要考算法。

可就在我以为面试要结束的时候,该来的还是来了。

题目:

给定两个字符串形式的非负整数 num1 和 num2,计算它们的和。
注意,不能把 string 转换为 int 后直接相加。

面试官笑了,我也笑了,好,我写一下。

我隐约记得是模拟人工手算:


<span>我倒在了美团面试算法题:字符串大数相加</span>

一位一位来加,有进位就在左边那位加个 1。

因为没有刷过题,只能按我自己的思路去写,越写越乱,最后还是没能写出来。

面完后,我不禁陷入了沉思。

测试需要学算法?部分需要。

哪些需要?大厂、高级职位、测试开发。

怎么练?刷题。

哪里刷?力扣。

本文就跟大家讲一下字符串大数相加的算法。希望在面试时被问到了,能自信的写出来。

对这个算法,首先要考虑的是,怎么来遍历这 2 个数,可以用 2 个指针,分别指向这 2 个数的尾部,边计算边向左移动。

数的长度可能会不一样,短的那个数的指针就会先到达最左边的头部,为了能够继续计算,可以给缺失的位补 0。

加数长度不一致的问题就解决了。

指针的数相加后,可以通过除以 10 的余数,来算出当前位的结果。

进位,则可以通过对 10 的整除数,来算。

例如:


<span>我倒在了美团面试算法题:字符串大数相加</span>

指针指向的 2 个数是 5 和 6。

5 + 6 = 11,用 tmp 变量来存,tmp = n1 + n2 + carry,因为有可能右边有进位,需要加上。

11 对 10 的整除数是 1,用 carry 来存进位。

11 除以 10 的余数是 1,用 res 来存结果,需要在 res 最左边添加 “1”,把 “9084” 变为 “19084”。

最后分析代码:

class Solution:
    # 加法函数,入参num1和num2,返回计算结果,str类型
    def addStrings(self, num1: str, num2: str) -> str:
        res = ""
        # 定义i,j两个指针,分别指向两个数的尾部
        # 定义进位,默认0
        i, j, carry = len(num1) - 1, len(num2) - 1, 0
        # 循环,直到2个指针都到达头部
        while i >= 0 or j >= 0:
            # 如果没有到达头部,就通过-'0'转为int
            # 如果到达头部了,就补0
            n1 = num1[i] - '0' if i >= 0 else 0
            n2 = num2[j] - '0' if j >= 0 else 0
            # n1 + n2 + carry
            tmp = n1 + n2 + carry
            # 进位 = 对10的整除数
            carry = tmp // 10
            # 结果左边添加除以10的余数
            res = str(tmp % 10) + res
            # 每次计算后向左移动1位
            i, j = i - 1, j - 1
        # 2个指针都到达了头部,如果还有进位,就在res左边添加"1"
        # 否则直接返回res
        return "1" + res if carry else res

参考资料:力扣 415. 字符串相加

最后的最后,希望大家都能找到满意的工作,拿到超高的薪资。我也会继续向大厂努力。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/2662.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • gimp中文版教程_GIMP中文教程.pdf

    gimp中文版教程_GIMP中文教程.pdfGimp中文教程(一)KangJS28年12月一.一.阴影(DropShadow)关键点:3个图层:1.背景图层(透明)2.阴影图层3.实景图层主要命令:路径(B),油漆桶填充(shift+B),混合填充(L),移动(M),滤镜–>高斯模糊操作流程:1.CTRL+N新建一个透明图层2.复制一个阴影图层,使用路径工具在此图层上勾画一个封闭路径并转为选区.3.复制阴…

    2022年6月26日
    108
  • 七牛云大数据平台建设实践

    七牛云大数据平台建设实践七牛云CEO许式伟首次披露七牛云在大数据方向的产品思路。

    2022年6月9日
    26
  • Xray基础使用介绍

    Xray基础使用介绍官方使用文档:https://docs.xray.cool/#xray简介xray是一款功能强大的安全评估工具,由多名经验丰富的一线安全从业者呕心打造而成,主要特性有:检测速度快。发包速度快;漏洞检测算法高效。支持范围广。大至OWASPTop10通用漏洞检测,小至各种CMS框架POC,均可以支持。代码质量高。编写代码的人员素质高,通过CodeReview、单元测试、集成测试等多层验证来提高代码可靠性。高级可定制。通过配置文件暴露了引擎的各种参数,通过修改配置文件可以极大的客

    2022年5月8日
    157
  • java下载文件下载不动_java文件下载的问题

    java下载文件下载不动_java文件下载的问题以前没写过文件下载的程序,现在在servlet中试了试,有些问题请教大神。代码如下:publicvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)throwsServletException…以前没写过文件下载的程序,现在在servlet中试了试,有些问题请教大神。代码如下:publicvoiddoPost(H…

    2022年7月8日
    18
  • java的定时器用法

    java的定时器用法

    2021年12月4日
    34
  • C语言操作EXCEL文件(读写)[通俗易懂]

    C语言操作EXCEL文件(读写)[通俗易懂]C语言操作EXCEL文件(读写)本文主要介绍通过纯C语言进行EXCEL的读写操作:C语言读操作C语言写操作在之前需要使用C语言读取Excel文件内容的功能,查阅了很多资料,大部分是通过ODBC或者过OLE/COM对Excel表格的读取操作,这变要求在工程中添加类,如CApplicaton及其头文件等,这包括Excel接口、导入类、头文件等。操作十分复杂,当然我也对这种方法进行…

    2022年5月12日
    176

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号