首页 > 其他 > 详细

[LeetCode]67. Add Binary

时间:2020-01-21 10:20:32      阅读:86      评论:0      收藏:0      [点我收藏+]

这道题其实和其他类似问题很相似,就是要处理carry的问题。时间复杂度是O(N),空间复杂度是O(1)

class Solution:
    def addBinary(self, a: str, b: str) -> str:
        i, j, carry = len(a) - 1, len(b) - 1, 0
        result = []
        while i >= 0 and j >= 0:
            digit = (int(a[i]) + int(b[j]) + carry) % 2
            carry = (int(a[i]) + int(b[j]) + carry) // 2
            result.insert(0, digit)
            i -= 1
            j -= 1
        while i >= 0:
            digit = (int(a[i]) + carry) % 2
            carry = (int(a[i]) + carry) // 2 
            result.insert(0, digit)
            i -= 1
            j -= 1
        while j >= 0:
            digit = (int(b[j]) + carry) % 2
            carry = (int(b[j]) + carry) // 2 
            result.insert(0, digit)
            i -= 1
            j -= 1
        if carry == 1:
            result.insert(0, carry)
        
        return ‘‘.join(map(str, result))

[LeetCode]67. Add Binary

原文:https://www.cnblogs.com/codingEskimo/p/12220204.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!