剑指 Offer II 002. 二进制加法python

题目描述:

 题解:

1.定义一个add函数,有a b c三个输入参数,分别对应两个加数和一个进位,innum,resnum两个返回参数,分别对应向前一位的进位和这一位的结果。如果a+b+c>=2,innum = 1,resnum = a+b+c-innum

2.判断输入a b两个参数长度是否相等,如果不想等,则将a b中较短的前面补0。

3.从a b最后一位开始调用add函数,结果保存在result数组中,然后将result数组按照逆序输出为字符串。

class Solution:
    def addBinary(self, a: str, b: str) -> str:
        def add(a, b, c):
            if a + b + c >= 2:
                innum = 1
                resnum = a + b + c - 2
            else:
                resnum = a + b + c
                innum = 0
            return resnum, innum

        newstr = ""
        if len(a) > len(b):
            for i in range(len(a) - len(b)):
                newstr = newstr + "0"
            b = newstr + b
        if len(b) > len(a):
            for i in range(len(b) - len(a)):
                newstr = newstr + "0"
            a = newstr + a
        result = []
        length = len(a)
        c = 0
        for i in range(length - 1, -1, -1):
            resnum, innum = add(int(a[i]), int(b[i]), c)
            result.append(resnum)
            c = innum
        if c > 0:
            result.append(c)
        resstr = ""
        for i in range(len(result) - 1, -1, -1):
            resstr = resstr + str(result[i])
        return resstr

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值