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

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

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

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


<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. 字符串相加

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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • h5网站模板_超全超实用的80个模板网站,我全部整理在这里了「建议收藏」

    h5网站模板_超全超实用的80个模板网站,我全部整理在这里了「建议收藏」如果你喜欢本文章,欢迎关注,评论和转发,谢谢!模板网站,可谓是当代最受欢迎的网站类型之一,只要提供的足够新颖能够满足需求,必然成为懒癌青年们的最爱。这些网站深受喜爱的原因是:大家想要实现某种设计需求,但窘于自己技术没达到,时间来不及现学现卖等诸多因素,反正就是做不出来。正当你焦头烂耳临近崩溃的时候,别人告诉你有现成又好看的模板,想问又有谁能拒绝呢?当然,模板网站不一定全是免费的,都需要你付出一些东…

  • navicat for mac激活码【中文破解版】

    (navicat for mac激活码)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.cn/100143.html…

  • springboot框架 目录结构

    springboot框架 目录结构目录结构src/main/java:主程序入口Application,可以通过直接运行该类来启动SpringBoot应用src/main/resources:配置目录,该目录用来存放应用的一些配置信息,比如应用名、服务端口、数据库配置等。由于我们应用了Web模块,因此产生了static目录与templates目录,前者用于存放静态资源,如图片、CSS、JavaScript等;后…

  • Java拖拽排序工具类「建议收藏」

    Java拖拽排序工具类「建议收藏」packagecom.ciih.jwt.util.sort;importjava.lang.reflect.Field;importjava.util.Collections;importjava.util.List;/***拖拽排序工具:此工具将传入的list重新排序后返回,使用者只需要将list重新存入数据库即可完成排序.*<>*拖拽排序必然牵扯到两个元素,被拖拽的元素和被挤压的元素.排序方式就存在两种,一种是两个元素进行交换位置,一种是一个元素拖到.

  • c++迭代器的实现_iterator迭代器用法

    c++迭代器的实现_iterator迭代器用法要访问顺序容器和关联容器中的元素,需要通过“迭代器(iterator)”进行。迭代器是一个变量,相当于容器和操纵容器的算法之间的中介。迭代器可以指向容器中的某个元素,通过迭代器就可以读写它指向的元素。从这一点上看,迭代器和指针类似。迭代器按照定义方式分成以下四种。正向迭代器,定义方法如下:容器类名::iterator 迭代器名;常量正向迭代器,定义方法如下:容器类名::cons…

  • uint和int的区别_int32和uint32

    uint和int的区别_int32和uint32本次测试的环境是Mac系统下,CPU64位。注意:go语言中的int的大小是和操作系统位数相关的;如果是32位操作系统,int类型的大小就是4字节;如果是64位操作系统,int类型的大小就是8个字节1、测试不同int类型占用字节数大小1.1、测试有符号int类型import( “testing” “unsafe” “math” “fmt”)funcTestIntSize(t*testing.T){ fmt.Println(“不同int类型占用的字节数大小:”)

发表回复

您的电子邮箱地址不会被公开。

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