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