[백준/파이썬] 3460. 이진수

jwKim·2023년 1월 5일
0

💻코테코테

목록 보기
3/42

< 과제 >

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

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

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

[ 예제 입력 1 ]
1
13

[ 예제 출력 ]
0 2 3

< 내 코드 >

T = int(input())

for k in range(T):
    n = bin(int(input()))[2:]

    for i in range(len(n)):
        char = n[-1-i]
        if char == '1':
            print(i, end=" ")

< 피드백 >

  • 알고리즘 연습을 많이 해야겠다고 생각했다. 이 문제만 1시간 가까이 잡고 있었고, 결국 구글링을 해서 겨우 통과했다,, 아직 시작한지 얼마 안됐다고는 하지만, 그래도 이건 조금 심한 것 같다.
  • python에 기본으로 내장되어있는 함수들과 기초 문법을 다시 살펴봐야할 것 같다. 파이썬이 한글처럼 자유자재로 나올 수 있게!

< 출처 >

0개의 댓글