Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- 편스토랑 우승상품
- Real or Not? NLP with Disaster Tweets
- gs25
- 캐치카페
- hackerrank
- Baekjoon
- 자연어처리
- SW Expert Academy
- programmers
- github
- ubuntu
- 금융문자분석경진대회
- dacon
- PYTHON
- 파이썬
- AI 경진대회
- 더현대서울 맛집
- 프로그래머스
- 프로그래머스 파이썬
- Git
- leetcode
- 백준
- Docker
- ChatGPT
- 데이콘
- 맥북
- 편스토랑
- Kaggle
- 우분투
- 코로나19
Archives
- Today
- Total
솜씨좋은장씨
[BaekJoon] 24389번 : 2의 보수 (Python) 본문
728x90
반응형
코딩 1일 1문제! 오늘의 문제는 백준의 2의 보수 입니다.
🧑🏻💻 문제 풀이
32비트 2진수의 2의 보수를 구한 다음
32비트 2진수와 2의 보수의 서로 다른 비트의 개수를 구하는 문제입니다.
2의 보수를 구하는 방법은
해당하는 숫자의 모든 비트를 반전시킨 뒤, 1을 더해 만들 수 있습니다.
먼저 32비트 2진수를 만들어주었습니다.
2진수를 만드는데에는 bin 함수를 사용하였고
이를 32비트로 만드는 데에는 앞에 0을 채워 자리수를 맞추어주는 zfill 을 활용하였습니다.
binary = list(bin(N)[2:].zfill(32))
이 비트를 반대로 반전 시키는 데에는 각 자리의 값을 -1 한 값의 절댓값을 구하는 방식으로 반전시켰습니다.
reverse_binary = [str(abs(int(bi)-1)) for bi in binary]
마지막으로 +1을 하는 것에는 함수를 하나 만들어주었습니다.
def plus_one(bin_num):
temp = 1
result = []
for bi_idx, bi in enumerate(bin_num[::-1]):
# print(f"bi - {bi}")
plus_result = int(bi) + temp
# print(f"plus_result - {plus_result}")
if plus_result > 1:
result.append("0")
else:
result.append("1")
temp = 0
if temp == 0:
break
return bin_num[:32-bi_idx-1] + result[::-1]
complement = plus_one(bin_num=reverse_binary)
plus_one 함수를 이용하여 +1 을 더하여 2의 보수 계산을 완료하였습니다.
for bi, co in zip(binary, complement):
if bi != co:
answer += 1
마지막으로 2진수와 2의 보수의 다른 비트의 개수를 구하면 끝!
전체 코드는 아래를 참고해주세요.
🧑🏻💻 코드 ( Solution )
def plus_one(bin_num):
temp = 1
result = []
for bi_idx, bi in enumerate(bin_num[::-1]):
# print(f"bi - {bi}")
plus_result = int(bi) + temp
# print(f"plus_result - {plus_result}")
if plus_result > 1:
result.append(str(0))
else:
result.append(str(1))
temp = 0
if temp == 0:
break
return bin_num[:32-bi_idx-1] + result[::-1]
def two_complement(N):
answer = 0
binary = list(bin(N)[2:].zfill(32))
reverse_binary = [str(abs(int(bi)-1)) for bi in binary]
# print("".join(binary))
# print("".join(reverse_binary))
complement = plus_one(bin_num=reverse_binary)
# print("".join(complement))
for bi, co in zip(binary, complement):
if bi != co:
answer += 1
return answer
if __name__ == "__main__":
N = int(input())
print(two_complement(N=N))
'Programming > 코딩 1일 1문제' 카테고리의 다른 글
[BaekJoon] 18398번 : HOMWRK (Python) (0) | 2022.11.28 |
---|---|
[BaekJoon] 25955번 : APC는 쉬운 난이도 순일까, 아닐까? (Python) (0) | 2022.11.27 |
[BaekJoon] 24608번 : Average Character (Python) (0) | 2022.11.25 |
[BaekJoon] 25773번 : Number Maximization (Python) (0) | 2022.11.24 |
[BaekJoon] 25859번 : Sort by Frequency (Python) (0) | 2022.11.22 |
Comments