[프로그래머스] 2개 이하로 다른 비트

Turtle·2024년 9월 1일
0
post-thumbnail

🗃️문제 설명

양의 정수 x에 대한 함수 f(x)를 다음과 같이 정의합니다.

  • x보다 크고 x와 비트가 1~2개 다른 수들 중에서 제일 작은 수

예를 들어,

f(2) = 3 입니다. 다음 표와 같이 2보다 큰 수들 중에서 비트가 다른 지점이 2개 이하이면서 제일 작은 수가 3이기 때문입니다.

비트다른 비트의 개수
2000...0010
3000...00111

f(7) = 11 입니다. 다음 표와 같이 7보다 큰 수들 중에서 비트가 다른 지점이 2개 이하이면서 제일 작은 수가 11이기 때문입니다.

비트다른 비트의 개수
7000...0111
8000...10004
9000...10013
10000...10103
11000...10112

정수들이 담긴 배열 numbers가 매개변수로 주어집니다. numbers의 모든 수들에 대하여 각 수의 f 값을 배열에 차례대로 담아 return 하도록 solution 함수를 완성해주세요.

🖥️코드

def solution(numbers):
    answer = []
    def f(number):
        if number % 2 == 0:
            return number + 1
        else:
            binnum = '0' + bin(number)[2:]
            binnum = binnum[:binnum.rindex('0')] + "10" + binnum[binnum.rindex('0') + 2:]
            return int(binnum, 2)

    for number in numbers:
        answer.append(f(number))
    return answer

🔒문제 출처

프로그래머스 - 2개 이하로 다른 비트

0개의 댓글