ZZULIOJ 1193: 单科成绩排序(结构体专题),Java
题目描述
有一学生成绩表,包括学号、姓名、3门课程成绩。请按要求排序输出:若输入1,则按第1门课成绩降序输出成绩表,若输入为i(1<=i<=3),则按第i门课成绩降序输出成绩表。
输入
首先输入一个整数n(1<=n<=100),表示学生人数;
然后输入n行,每行包含一个学生的信息:学号(12位)、姓名(不含空格且不超过20位),以及3个整数,表示3门课成绩,数据之间用空格隔开。
最后一行输入一个整数i,表示要求按第i门课成绩降序排序输出,若该门课成绩相同,则按学号升序。
输出
输出按第i门课降序排序的结果,格式见样例。
样例输入 Copy
3
541207010188 Zhangling 89 78 95
541207010189 Wangli 85 87 99
541207010190 Fangfang 85 68 76
1
样例输出 Copy
541207010188 Zhangling 89 78 95
541207010189 Wangli 85 87 99
541207010190 Fangfang 85 68 76
import java.util.ArrayList;
import java.util.Collections;
import java.util.Scanner;
class Student {
String id;
String name;
int[] scores;
public Student(String id, String name, int[] scores) {
this.id = id;
this.name = name;
this.scores = scores;
}
}
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
ArrayList<Student> students = new ArrayList<>();
for (int i = 0; i < n; i++) {
String id = sc.next();
String name = sc.next();
int[] scores = new int[3];
for (int j = 0; j < 3; j++) {
scores[j] = sc.nextInt();
}
students.add(new Student(id, name, scores));
}
int i = sc.nextInt();
Collections.sort(students, (s1, s2) -> {
if (s1.scores[i - 1] != s2.scores[i - 1]) {
return Integer.compare(s2.scores[i - 1], s1.scores[i - 1]);
} else {
return s1.id.compareTo(s2.id);
}
});
for (Student student : students) {
System.out.println(student.id + " " + student.name + " " + student.scores[0] + " " + student.scores[1] + " " + student.scores[2]);
}
}
}