3.5 KiB
3.5 KiB
deck:: Logseq/coding tip
-
► 유틸 함수 모음
-
◼︎ 정렬함수 (Arrays.sort(), Collections.sort())
- ◉ Arrays.sort()
- 문법 및 기본 특징 #card
id:: 692d5485-5781-449e-9e19-292d1343523b
-
// 정적인 기본타입의 배열을 정렬 할 때 사용하는 함수, 원본배열을 변경함. // int[], char[], String[], T[] // 1. 전체 정렬 (모든 원소를 오름차순 정렬) Arrays.sort(arr); // 2. 전체 정렬 (내림차순 정렬) // int[] 형은 지원 안함. 객체 배열(Integer[], String[] 혹은 클래스의 배열만 지원) Arrays.sort(arr, Collections.reverseOrder());
-
- 커스텀 정렬(Comparator) #card
id:: 692d5495-2c26-49c2-9585-fd0f1c27285f
-
// 기본적으로 객체 배열만 가능 // 매개변수로 람다식을 넣어서 정렬기준을 임의로 지정 가능함 Arrays.sort(arr, (a,b) -> b - a); //내림차순 정렬 Arrays.sort(students, (s1, s2) -> Integer.compare(s1.score, s2.score)); // 점수 기준 오름차순 Arrays.sort(students, (s1, s2) -> { if(s1.score == s2.score) return Integer.compare(s2.age, s1.age); return Integer.compare(s1.score, s2.score); }); // 점수 기준 오름차순, 점수가 같다면 나이 기ㄹ준 내림차순
-
- 문법 및 기본 특징 #card
id:: 692d5485-5781-449e-9e19-292d1343523b
- ◉ Arrays.sort()
- ◉ Collections.sort()
- 문법 및 기본 특징 #card
id:: 692d58fc-1b8e-4d8f-ad72-514fc08d936f
-
// List 인터페이스 구현체를 정렬할 때 사용 // ArrayList, LinkedList, Vector 등등 // 1. 전체 정렬 (모든 원소를 기본 정렬기준에 따라 오름차순 정렬) Collections.sort(list); // 2. 전체 정렬 (내림차순 정렬) Collections.sort(list, Collections.reverseOrder());
-
- 커스텀 정렬(Comparator) #card
id:: 692d5a74-e198-4be0-b6e4-ee17b5796b83
-
// 매개변수로 람다식을 넣어서 정렬기준을 임의로 지정 가능함 Collections.sort(list, (s1, s2) -> Integer.compare(s1.length, s2.length)); // 리스트에 저장된 각 원소의 길이에 따라 오름차순 정렬
-
- 문법 및 기본 특징 #card
id:: 692d58fc-1b8e-4d8f-ad72-514fc08d936f
- ◉ Comparable 정렬
- 문법 #card #depth-1
id:: 692d5ce2-4655-4fad-bfaf-2021a0916e19
- 클래스를 선언할 때 Comparable 인터페이스를 불러와서 선언함.
- 클래스 내부에 public int compareTo() 함수를 오버라이딩해서 구현함.
- 예제코드(Arrays.sort(), Collections.sort() 각각 사용) #card
id:: 692d5dbe-6593-4a4f-93a7-8fa34b198e6f
-
class Student implements Comparable<Student> { String name; int score; public Student(String name, int score) { this.name = name; this.score = score; } @Override public int compareTo(Student o) { // 점수 기준 오름차순 (내 점수 - 남 점수) return Integer.compare(this.score, o.score); } } // Arrays.sort() 사용 Student[] students; // 알아서 배열 채워넣었다고 가정함. Arrays.sort(students); // Collections.sort() 사용 List<Student> students = new ArrayList<>(); // 알아서 채워넣었다고 가정 Collections.sort(students); students.sort(Comparator.naturalOrder()); // java8 이후 students.sort(); // 변수 없이 해도 가능
-
- 문법 #card #depth-1
id:: 692d5ce2-4655-4fad-bfaf-2021a0916e19
-