-
Notifications
You must be signed in to change notification settings - Fork 25
/
Copy pathP3_1.java
47 lines (40 loc) · 1.79 KB
/
P3_1.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
package ch06;
import java.util.ArrayList;
import java.util.List;
public class P3_1 {
public String[] reorderLogFiles(String[] logs) {
// 문자 로그를 저장할 문자 리스트
List<String> letterList = new ArrayList<>();
// 숫자 로그를 저장할 숫자 리스트
List<String> digitList = new ArrayList<>();
for (String log : logs) {
// 로그 종류 확인 후 숫자 로그라면 숫자 리스트에 삽입
if (Character.isDigit(log.split(" ")[1].charAt(0))) {
digitList.add(log);
} else {
// 숫자 로그가 아니라면 문자 리스트에 삽입
letterList.add(log);
}
}
// 문자 리스트 정렬 진행
letterList.sort((s1, s2) -> {
// 식별자와 식별자 외 나머지 부분, 이렇게 두 부분으로 나눈다.
String[] s1x = s1.split(" ", 2);
String[] s2x = s2.split(" ", 2);
// 문자 로그 사전순 비교
int compared = s1x[1].compareTo(s2x[1]);
// 문자가 동일한 경우 식별자 비교하여 먼저 리턴
if (compared == 0) {
return s1x[0].compareTo(s2x[0]);
} else {
// 비교 대상의 순서가 동일한 경우 0, 순서가 앞인 경우 1, 순서가 뒤인 경우 -1이 된다.
return compared;
}
});
// 문자 리스트 뒤로 숫자 리스트를 이어 붙인다.
// 숫자 로그는 '입력 순서대로'라는 제약 조건이 있으므로 따로 정렬하지 않는다.
letterList.addAll(digitList);
// 리스트를 String 배열로 변환해 리턴한다.
return letterList.toArray(new String[0]);
}
}