[기초] 백준 3460번: 이진수 (파이썬)

Donburi·2022년 5월 25일
0

PS (Old)

목록 보기
16/24

문제

양의 정수 n이 주어졌을 때, 이를 이진수로 나타냈을 때 1의 위치를 모두 찾는 프로그램을 작성하시오. 최하위 비트(least significant bit, lsb)의 위치는 0이다.

입력

첫째 줄에 테스트 케이스의 개수 T가 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있고, n이 주어진다. (1 ≤ T ≤ 10, 1 ≤ n ≤ 106)

출력

각 테스트 케이스에 대해서, 1의 위치를 공백으로 구분해서 줄 하나에 출력한다. 위치가 낮은 것부터 출력한다.

풀이

t = int(input())
for _ in range(t):
    n = int(input())
    b = format(n, 'b')[::-1]
    for i in range(len(b)):
        if b[i] == '1':
            print(i)

메모

이진수로 변환하기 위해 bin()을 활용해도 되지만 접두어가 붙는다.
풀이처럼 format()을 활용한 변환이 가능하다.


Reference

문제 선택: 코딩테스트 시작을 위한 백준 문제 추천
진수 변환 관련 좋은 글: [파이썬] 2진수, 8진수, 16진수 다루기

0개의 댓글