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