티스토리 뷰

728x90
반응형

문제

programmers.co.kr/learn/courses/30/lessons/12911

 

코딩테스트 연습 - 다음 큰 숫자

자연수 n이 주어졌을 때, n의 다음 큰 숫자는 다음과 같이 정의 합니다. 조건 1. n의 다음 큰 숫자는 n보다 큰 자연수 입니다. 조건 2. n의 다음 큰 숫자와 n은 2진수로 변환했을 때 1의 갯수가 같습니

programmers.co.kr

 

코드

def solution(n):
    answer = 0
    c = bin(n).count("1")
    for m in range(n+1, 1000001):
        if c == bin(m).count("1"):
            answer = m
            break
    return answer

python에 bin()을 이용해 이진수로 만들어주고 count()를 이용해 1의 갯수를 세어준다.

 

그리고 입력한 값보다 +1 한 값에서 부터 문제에 범위까지 for문을 돌아 1의 갯수가 같을 경우 바로 break문을 실행해 가장 작은 수를 구한다.

반응형
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/11   »
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