[LeetCode] 067. Add Binary
-
date_range April 10, 2019 - Wednesday info
- Problem (Easy)
- Approach 1: (My Solution - Convert to Numbers)
- Approach 2: (My Solution - Operate Directly)
Problem (Easy)
Given two binary strings, return their sum (also a binary string).
The input strings are both non-empty and contains only characters 1 or 0.
Example 1:
- Input: a = “11”, b = “1”
- Output: “100”
Example 2:
- Input: a = “1010”, b = “1011”
- Output: “10101”
Approach 1: (My Solution - Convert to Numbers)
Idea
- Convert
a
andb
to numbers; - Add two numbers;
- Convert the result back to string and slice.
Solution
class Solution1:
def addBinary(self, a, b):
"""
:type a: str
:type b: str
:rtype: str
"""
return bin(int(a, 2) + int(b, 2))[2:]
Complexity
- Time: $O(n)$
- Space: $O(n)$
Approach 2: (My Solution - Operate Directly)
Idea
- Loop adding operation bit by bit from right to left;
- Use the
divmod
method.
Solution
class Solution2:
def addBinary(self, a, b):
"""
:type a: str
:type b: str
:rtype: str
"""
a, b = sorted((a,b), key=len)
inc, res = 0, ''
for i in range(len(b)):
if i < len(a):
inc, tmp = divmod(int(b[-1-i]) + int(a[-1-i]) + inc, 2)
res = str(tmp) + res
else:
inc, tmp = divmod(int(b[-1-i]) + inc, 2)
res = str(tmp) + res
if inc:
res = '1' + res
return res
Complexity
- Time: $O()$
- Space: $O()$
shravan