본문 바로가기
코딩테스트/Java

[Level2] 다음 큰 숫자 답안 및 풀이

by SRin23 2021. 12. 27.

◇ 문제 설명

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

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

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

자연수 n이 매개변수로 주어질 때, n의 다음 큰 숫자를 return 하는 solution 함수를 완성해주세요.

 

◇ 제한 조건

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

 

◇ 입출력 예시

n result
78 83
15 23

 

◇ 입출력 예 설명

입출력 예#1
문제 예시와 같습니다.


입출력 예#2
15(1111)의 다음 큰 숫자는 23(10111)입니다.

 

◇ 초기 내용

※ [출처] 프로그래머스-코딩테스트 연습-문제명

※ 초기 내용을 참고하여 문제에 맞는 코드를 작성하세요.

class Solution {
    public int solution(int n) {
        int answer = 0;
        return answer;
    }
}

 


◇ 풀이 과정

문제의 풀이과정은 이러했다.

  1. n을 2진수로 변환한다.
  2. 변환된 2진수에서 1의 개수를 count한다.
  3. 다음 큰 수는 n보다 크므로 n보다 큰 수중 n의 2진수와 1의 개수가 같은 수를 찾는다.
  4. 첫번째로 만난 n의 2진수와 같은 수를 찾으면 break한 후 값을 return한다.

 

◇  참고 사항

첫번째, 이진수 변환하기

Integer.toBinaryString(n)

  • 10진수 n을 2진수로 변환해주는 메서드이다.
  • 반환값은 String형이다.

두번째, charAt(i)

  • String의 각 문자에 접근하기 위해서는 str.charAt(index)메서드를 사용한다.
  • 각 문자가 char형태로 반환된다.

 

 

◇ 답안

더보기
더보기
class Solution {
    public int solution(int n) {
        int answer = 0;
        
        //n을 2진수로 변환 후, 1의 개수 구하기
        int cnt = 0;
        String binaryString = Integer.toBinaryString(n); 
        for(int i = 0; i<binaryString.length(); i++){
            if(binaryString.charAt(i)=='1'){
                cnt++;
            }
        }
        
        //n보다 큰 수 중 2진수로 변환한 값의 1개수가 n과 같은 값 구하기
        while(true){
            int chCnt = 0;
            String binaryString2 = Integer.toBinaryString(++n); 
            for(int i = 0; i<binaryString2.length(); i++){
                if(binaryString2.charAt(i)=='1'){
                    chCnt++;
                }
            }
            if(cnt==chCnt){
                answer = n;
                break;
            }
        }
        
        return answer;
    }
}

 

◇ 실행결과

다음 큰 숫자 실행결과

 

◇ 출처

https://programmers.co.kr/learn/challenges

 

코딩테스트 연습

기초부터 차근차근, 직접 코드를 작성해 보세요.

programmers.co.kr

 

댓글