다음 큰 숫자

KyungUp·2022년 9월 19일
0

코딩테스트

목록 보기
3/7

문제 설명

자연수 n이 주어졌을 때, n의 다음 큰 숫자는 다음과 같이 정의 합니다.

  • 조건 1. n의 다음 큰 숫자는 n보다 큰 자연수 입니다.
  • 조건 2. n의 다음 큰 숫자와 n은 2진수로 변환했을 때 1의 갯수가 같습니다.
  • 조건 3. n의 다음 큰 숫자는 조건 1, 2를 만족하는 수 중 가장 작은 수 입니다.

예를 들어서 78(1001110)의 다음 큰 숫자는 83(1010011)입니다.

제한 조건

  • n은 1,000,000 이하의 자연수 입니다.

입출력 예

n	result
78	83
15	23

풀이 과정

function solution(n) {
    const arr = (num) => {
        return [...num.toString(2)].filter(value => value !== '0')
    }

    let answer = 0
    let next = n + 1

    while (true) {
        if (arr(n).length === arr(next++).length) {
            answer = next - 1
            break
        }
    }

    return answer
}

코드 실행

Tip.

  1. 주어진 값을 이진법 변경 (X.toString(2))
  2. Destructuring 으로 변경 한 이진법을 배열 생성
  3. 생성된 배열를 filter를 사용하여, 값이 0 이상인 값만 가져오도록 변경
  4. while 반복문을 사용하여, 주어진 값을 하나씩 추가
  5. 반복문 안에 2~3번 순서를 넣고, 길이가 같을때 answer 변수에 해당 숫자 선언

참고자료

profile
Last Epoch하고싶다

0개의 댓글