Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 데이터베이스
- githubactions
- java
- 국제화
- 백준
- 파이썬
- oauth2
- 오블완
- yaml-resource-bundle
- springsecurityoauth2client
- springsecurity
- AWS
- 리프레시토큰
- 스프링시큐리티
- Spring
- 프로그래머스
- 티스토리챌린지
- 토이프로젝트
- CI/CD
- docker
- 스프링부트
- springdataredis
- JIRA
- 트랜잭션
- 스프링
- 소셜로그인
- 액세스토큰
- 재갱신
- 도커
- 메시지
Archives
- Today
- Total
땃쥐네
[백준] [24389] [Python] 2의 보수 본문
문제
- 플랫폼 : 백준
- 번호 : 24389
- 제목 : 2의 보수
- 난이도 : Bronze 1
- 2의 보수는 해당하는 숫자의 모든 비트를 반전시킨 뒤, 1을 더해 만들 수 있다.
이때, 32비트 기준으로 처음 표현했던 수와 그 2의 보수의 서로 다른 비트 수를 출력하기 - 문제 : 링크
필요 알고리즘
비트의 합 연산
- 두 비트 a, b가 있을 때 비트의 합 연산은 다음과 같다. carry_out은 자리 올림이고, sum은 해당 자리에 남는 수이다.
- carry_out : a and b
- sum : a xor b
풀이
bits_a = [True if bit == '1' else False for bit in bin(int(input()))[2:].rjust(32, '0')]
bits_b = [not bit for bit in bits_a]
carry = True
for idx in range(len(bits_b) - 1, -1, -1):
if not carry:
break
bits_b[idx], carry = bits_b[idx] != carry, bits_b[idx] and carry
answer = len([1 for bit_a, bit_b in zip(bits_a, bits_b) if bit_a != bit_b])
print(answer, end='')
- 숫자를 입력받아서, bin을 통해 이진 문자열로 변환한다.
- 이렇게 되면 2의 경우 0b10이 되는데 32비트에 맞추도록 rjust를 통해 32자리로 맞춘다.
- 계산의 편의를 위해 각 자리를 True, False 의 불값으로 변환한다.
- 이렇게 만들어진 bits_a는 원래 숫자를 비트로 변환한 것들의 배열이다.
- bits_b는 비트를 뒤집고 여기에 1을 더한 수의 배열이여야한다.
- not 연산을 통해 모든 비트를 뒤집는다.
- 1을 더하는 작업은 반복문을 통해 수행한다. 초기 carry를 True로 한다.
- 각 자리별로 Carry와 비트의 합 연산을 수행한다. 위에서 설명한 진리표에 따르면 sum은 xor 연산, carry는 and 연산을 통해 구한다.
- Carry가 False가 되면 그 이후 비트는 변할 일이 없으므로, 반복문을 탈출한다.
결과
36ms 정도 시간이 소요된다.
'Algorithm > Baekjoon Online Judge' 카테고리의 다른 글
[백준] [01865] [Python] 웜홀 (0) | 2023.02.08 |
---|---|
[백준] [10815] [Python] 숫자 카드 (0) | 2023.02.08 |
[백준] [14503] [Python] 로봇 청소기 (0) | 2023.02.07 |
[백준] [02606] [Python] 바이러스 (0) | 2023.02.04 |
[백준] [02018] [Python] 수들의 합 5 (0) | 2023.01.26 |
Comments