728x90
https://www.acmicpc.net/problem/10825
메모리: 61,104 KB , 시간: 664 ms
사용 알고리즘: 정렬
728x90
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.StringTokenizer;
public class Main {
static class Student implements Comparable{
String name;
int kor;
int eng;
int math;
public Student(String name, int kor, int eng, int math) {
this.name = name;
this.kor = kor;
this.eng = eng;
this.math = math;
}
@Override
public int compareTo(Object o) {
Student s = (Student) o;
if(this.kor != s.kor) { // 국어 점수가 감소하는 순서로
return s.kor - this.kor;
} else { // 국어 점수가 같으면
if(this.eng != s.eng) { // 영어 점수가 증가하는 순서로
return this.eng - s.eng;
}else { // 국어, 영어 점수가 같으면
if(this.math != s.math) { // 수학 점수가 감소하는 순서로
return s.math - this.math;
} else { // 모든 점수가 같으면 이름 사전 순
return this.name.compareTo(s.name);
}
}
}
}
}
public static void main(String[] args) throws Exception{
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st;
int N = Integer.parseInt(br.readLine());
Student[] students = new Student[N];
String name; int kor, eng, math;
for (int i = 0; i < N; i++) {
st = new StringTokenizer(br.readLine());
name = st.nextToken();
kor = Integer.parseInt(st.nextToken());
eng = Integer.parseInt(st.nextToken());
math = Integer.parseInt(st.nextToken());
students[i] = new Student(name, kor, eng, math);
}
Arrays.sort(students);
StringBuilder result = new StringBuilder();
for (int i = 0; i < N; i++) {
result.append(students[i].name).append("\n");
}
System.out.println(result);
}
}
728x90
'Problem Solving > BOJ' 카테고리의 다른 글
[백준, BOJ 20119] 클레어와 물약 (java) (1) | 2024.10.14 |
---|---|
[백준, BOJ 1439] 뒤집기 (java) (0) | 2024.10.14 |
[백준, BOJ 10282] 해킹 (java) (0) | 2024.10.11 |
[백준, BOJ 2816] 디지털 티비 (java) (3) | 2024.10.11 |
[백준, BOJ 1145] 적어도 대부분의 배수 (java) (0) | 2024.10.11 |