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 answerpython에 bin()을 이용해 이진수로 만들어주고 count()를 이용해 1의 갯수를 세어준다.
그리고 입력한 값보다 +1 한 값에서 부터 문제에 범위까지 for문을 돌아 1의 갯수가 같을 경우 바로 break문을 실행해 가장 작은 수를 구한다.
반응형
    
    
    
  '알고리즘 > 프로그래머스' 카테고리의 다른 글
| [프로그래머스] Level3, 2 x n 타일링 (Python) (0) | 2021.05.05 | 
|---|---|
| [프로그래머스] Level2, 위장 (Python) (0) | 2021.05.02 | 
| [프로그래머스] Level2, 기능 개발 (Python) (0) | 2021.05.02 | 
| [프로그래머스] Level2, 주식가격 (Python) (0) | 2021.04.30 | 
| [프로그래머스] Level 1, 같은숫자는 싫어 (Python) (0) | 2021.03.18 |