알고리즘 공부 - Day15

설하나·2022년 11월 22일
0

알고리즘

목록 보기
15/22

오늘의 알고리즘을 풀어보자😎

1. 다음 큰 숫자

[문제 상황]

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

조건 1. n의 다음 큰 숫자는 n보다 큰 자연수 입니다.
조건 2. n의 다음 큰 숫자와 n은 2진수로 변환했을 때 1의 갯수가 같습니다.
조건 3. n의 다음 큰 숫자는 조건 1, 2를 만족하는 수 중 가장 작은 수 입니다.
" 예를 들어서 78(1001110)의 다음 큰 숫자는 83(1010011)입니다. "

자연수 n이 매개변수로 주어질 때, n의 다음 큰 숫자를 리턴

[풀이 코드]

function solution(n) {
    let answer = n;
    const nCountOne = n.toString(2).match(/1/g).length
    while(true){
        answer++
        if(nCountOne === (answer).toString(2).match(/1/g).length) break
    }
    return answer;
}

[문제 해결 방향]

주어진 숫자를 answer에 할당을 하고, toString()매서드를 통해 10진수를 2진수를 바꾸었다.이후 match()매서드를 통해서 정규식에서 일치하는 부분의 길이를 nCountOne 변수에 저장하였다.
그 후 while()문을 통해서 기존의 수를 하나씩 들려가다가 위와 똑같이 매서드를 적용하였을때, 같다면 break를 통해 반복문을 나오도록 설계하였다.

profile
Backend

0개의 댓글