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]);}}
}