정답

    public int reverseInt(int n) {
        int i = 1;
    
        // 1) 정수의 자릿수를 구한다.
        int count = 0;
        while(i<=n) {
            i = i*10;
            count++;
        }
        i = i/10;
        int arrCount = 0;
        // 2) 자릿수 크기만큼의 정수 배열을 선언한다.
        int[] arr = new int[count];
    
        // 3) 해설의 2)에서 구한 배열에 각 자리의 수를 저장한다.
        while(n>0) {
            arr[arrCount] = n/i;
            n = n%i;
            i = i/10;
            arrCount++;
        }
    
        // 4) 배열에 있는 값을 내림차순으로 정렬한다.
        int temp = -1;
        for (int i2 = 0; i2 < arr.length; i2++) {
            for (int j = i2 + 1; j < arr.length; j++) {
                if (arr[i2] < arr[j]) {
                    temp = arr[i2];
                    arr[i2] = arr[j];
                    arr[j] = temp;
                }
            }
        }
    
        // 5) 배열에 있는 값을 이용해 다시 정수를 만든다.
        int value = 0;
        if(arr.length > 0) {
            value = arr[0];
            if(arr.length > 1) {
                for (int i3 = 1; i3 < arr.length; i3++) {
                    value = value * 10 + arr[i3];
                }
            }
        }
    
        return value;
    }

     

    해설

    reverseInt는 다음과 같은 순서로 문제를 해결해야 합니다.

     

    1 | 정수의 자릿수를 구한다.

    2 | 자릿수 크기만큼의 정수 배열을 선언한다.

    3 | 2에서 구한 배열에 각 자리의 수를 저장한다.

    4 | | 배열에 있는 값을 내림차순으로 정렬한다.

    5 | 배열에 있는 값을 이용해 다시 정수를 만든다.

     

    각 단계별 코드는 주석문의 코드를 확인해주세요.

    신간 소식 구독하기
    뉴스레터에 가입하시고 이메일로 신간 소식을 받아 보세요.