더북(TheBook)

정답

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 | 배열에 있는 값을 이용해 다시 정수를 만든다.

 

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

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