문돌이 존버/프로그래밍 스터디
(leetcode 문제 풀이) Add Binary
애뚱
2021. 9. 26. 21:36
반응형
Given two binary strings a and b, return their sum as a binary string.
Example 1:
Input: a = "11", b = "1"
Output: "100"
Example 2:
Input: a = "1010", b = "1011"
Output: "10101"
Constraints:
- 1 <= a.length, b.length <= 10^4
- a and b consist only of '0' or '1' characters.
- Each string does not contain leading zeros except for the zero itself.
class Solution:
def addBinary(self, a: str, b: str) -> str:
answer = ''
# 자릿수 맞추기
if len(a) != len(b):
if len(a) > len(b):
for _ in range(len(a) - len(b)):
b = '0' + b
else:
for _ in range(len(b) - len(a)):
a = '0' + a
std_len = max(len(a), len(b))
# 맨 뒤의 원소를 먼저 비교해서 높임 여부 확인
if a[-1] == '1' and b[-1] == '1':
carry = True
answer = '0' + answer
else:
carry = False
if a[-1] == '0' and b[-1] == '0':
answer = '0' + answer
else: # 둘 중 하나만 1인 경우
answer = '1' + answer
for i in range(std_len - 2, -1, -1): # 뒤에서 2번째 원소부터 진행
if a[i] == '1' or b[i] == '1':
if a[i] == '1' and b[i] == '1':
if carry == True:
answer = '1' + answer
else:
answer = '0' + answer
carry = True # 항상 True가 되어야 함
else: # 둘 중 하나만 1일 경우
if carry == True:
answer = '0' + answer
else:
answer = '1' + answer
else: # 둘 다 0일 경우
if carry == True:
answer = '1' + answer
else:
answer = '0' + answer
carry = False # 항상 False가 되어야 함
# 자릿수 넘어가는 경우 확인
if carry == True:
answer = '1' + answer
return answer
문제 자체는 굉장히 간단하다. 이진수끼리 연산을 해서 나온 결과값을 이진수로 리턴하면 된다.
파이썬의 내장 함수를 사용하면 바로 해결될 문제지만, 함수에 의존하지 않고자 직접 논리를 구현하기로 했다. 위의 코드를 보면 단계별로 차근차근 구현해 나간 것을 알 수 있다.
1) 자릿수를 맞추고(짧은 변수에 0을 앞에서부터 추가),
2) 마지막 원소를 먼저 확인해서 높임 여부 확인,
3) 연산 논리 구현
아래는 파이썬 내장 함수인 int(), bin()을 사용한 케이스다. 사실 5줄이면 끝나는 문제지만 처음부터 구현하면 위의 코드처럼 길어짐을 알 수 있다..
# 파이썬 내장 함수 사용
class Solution:
def addBinary(self, a: str, b: str) -> str:
a = int(a, 2) # 10진수로 변환
b = int(b, 2)
a = a + b
del b
return bin(a)[2:] # 2진수로 변환('0b'가 앞에 무조건 붙음)
728x90
반응형