작성
·
100
0
static class AscComparator implements Comparator<Integer>{
@Override
public int compare(Integer o1, Integer o2) {
System.out.println("o1=" + o1 +" o2=" + o2);
return (o1 < o2) ? -1 : ((o1==o2) ? 0 :1);
}
}
위 메서드에 대하여 질문을 드립니다.
Integer[] arr = {3,2,1}을 설정하였고
Arrays.sort(arr , new AscComparator());
기존 배열을 정렬하는데 제시된 기준으로 정렬을 할 것이라는 것까지는 이해하였습니다.
해당 메서드의 경우 o1 & o2에 대한 값을 먼저 출력을 한다음 서로 값 비교를 하는데
왜 o1에는 3이 아니라 2가 출력이 되고 o2에는 3이 출력되는지 궁금합니다.
답변 1
2
안녕하세요. 옙버디님, 공식 서포터즈 OMG입니다.
강의에서 영한님이 말씀하신 것처럼 TimSort가 동작하여 정렬이 이뤄지는데요,
실행흐름(빨간선)을 보면 TimSort클래스가 호출한 것을 볼 수 있습니다.
관련 함수를 확인하여 compare 함수의 첫번째 인자 o1과 두번째 인자 o2를 어떻게 넣어주는지 확인을 해보았는데,
첫번째 인자의 o1은 a[runHi++]값을, 두번째 인자는 a[lo]값을 인자로 전달하였습니다.
처음으로 compare()를 호출하는 시점 기준
a는 Integer[] array = {3, 2, 1};
lo는 첫번째 요소의 인덱스 (값: 0)
runHi는 lo +1 (값: 0 + 1 = 1)
이므로 아래 코드 기준으로
c.compare(a[1], a[0])이 호출되어 3, 2가 아닌 2, 3 순서로 호출하게 됩니다.
감사합니다.