문서 색인

1. 문제

출처 : 프로그래머스

어떤 수 N(1≤N≤1,000,000) 이 주어졌을 때, N의 다음 큰 숫자는 다음과 같습니다.

    N의 다음 큰 숫자는 N을 2진수로 바꾸었을 때의 1의 개수와 같은 개수로 이루어진 수입니다.
    1번째 조건을 만족하는 숫자들 중 N보다 큰 수 중에서 가장 작은 숫자를 찾아야 합니다.

예를 들어, 78을 2진수로 바꾸면 1001110 이며, 78의 다음 큰 숫자는 83으로 2진수는 1010011 입니다.
N이 주어질 때, N의 다음 큰 숫자를 찾는 nextBigNumber 함수를 완성하세요.


2. 코드

public class NextBigNumber {
    private int nextBigNumber(int n) {
        int count = bitCount(n);
        while ( true ) {
            n++;
            if ( count == bitCount(n) )
                break;
        }
        return n;
    }
 
    private int bitCount(int n) {
        String binNum = Integer.toBinaryString(n);
        int count = 0;
        for ( int inx=0; inx<binNum.length(); inx++ ) {
            char c = binNum.charAt(inx);
            if ( c == '1' ) {
                count++;
            }
        }
        return count;
    }
 
    public static void main(String[] args) {
        NextBigNumber nbn = new NextBigNumber();
        int n = 78;
        System.out.println(nbn.nextBigNumber(n));
    }
}