정렬과 관련된 interface는 Comparable, Comparator 이렇게 두 가지가 있다.
public class ListSortTest01 {
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<>();
list.add("일지매");
list.add("홍길동");
list.add("성춘향");
list.add("변학도");
list.add("이순신");
System.out.println("정렬 전 : " + list);
문자를 오름차순으로 정렬한다면? : 가나다 순, 알파벳 순
정렬은 Collections.sort()메서드를 이용해서 정렬한다.
Collecteions.sort()메서드는 기본적으로 내부 정렬 기준으로 정렬한다.
내부 정렬 기준 => Collection에 추가되는 데이터 자체에 구성된 정렬 기준(지금은 String의 내부 정렬기준)
=> 기본적인 자료형의 내부 정렬 기준은 오름차순으로 정렬되도록 만들어져 있다.
Collections.sort(list);
System.out.println("정렬 후: "+ list);
Collections.shuffle(list); //자료 섞기
System.out.println("자료 섞기 후: " + list);
//외부 정렬 기준을 사용해서 정렬하기
Collections.sort(list, new Desc());
System.out.println("내림차순 정렬 후 : " + list);
정렬 방식을 정해주는 class만들기 (외부 정렬 기준 class만들기)
class Desc implements Comparator<String>{
compare 메서드의 반환값
- 반환값이 0이면 ==> 두 값이 같다.
- 반환값이 양수 ==> 두 값의 순서를 바꾼다.
- 반환값이 음수 ==> 두 값의 순서를 바꾸지 않는다.
예) 오름차순일 경우 ==> 앞의 값이 크면 양수, 같으면 0
뒤의 값이 크면 음수가 반환되도록 구현한다.
오름차순(점점 커지는 것): 1,2,3,4,5,6,7,8,9
@Override
public int compare(String str1, String str2) {
//내림 차순으로 구현하려고 한다.
/*if(str1.compareTo(str2) > 0){
return -1;
}else if(str1.compareTo(str2) < 0){
return 1;
}else{
return 0;
}*/
return str1.compareTo(str2)*-1;
//컴퓨터는 기본적으로 오름차순인데 -1을 곱해서 내림차순 시켜줌