在某次考试中,学生的成绩信息如下: 姓名 年龄 成绩 请分别用Comparable和Comparator两个接口对以上同学的成绩做降序排序,如果成绩一样,那在成绩排序的基础上按照年龄由小到大排序,成绩和年龄都一样,则按照姓名的字典顺序排序。
时间: 2023-04-12 21:01:22 浏览: 224
好的,这是一个关于Java编程的问题。我们可以使用Comparable接口来实现学生对象的自然排序,也可以使用Comparator接口来实现定制排序。下面是使用Comparator接口实现的代码:
```java
import java.util.*;
class Student {
private String name;
private int age;
private int score;
public Student(String name, int age, int score) {
this.name = name;
this.age = age;
this.score = score;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
public int getScore() {
return score;
}
public String toString() {
return name + " " + age + " " + score;
}
}
class ScoreComparator implements Comparator<Student> {
public int compare(Student s1, Student s2) {
if (s1.getScore() != s2.getScore()) {
return s2.getScore() - s1.getScore();
} else if (s1.getAge() != s2.getAge()) {
return s1.getAge() - s2.getAge();
} else {
return s1.getName().compareTo(s2.getName());
}
}
}
public class Main {
public static void main(String[] args) {
List<Student> students = new ArrayList<>();
students.add(new Student("Tom", 20, 80));
students.add(new Student("Jerry", 18, 90));
students.add(new Student("Alice", 19, 80));
students.add(new Student("Bob", 20, 70));
Collections.sort(students, new ScoreComparator());
for (Student s : students) {
System.out.println(s);
}
}
}
```
输出结果为:
```
Jerry 18 90
Alice 19 80
Tom 20 80
Bob 20 70
```
这里我们使用了ScoreComparator类来实现定制排序,它实现了Comparator接口,并重写了compare方法。在compare方法中,我们首先比较学生的成绩,如果成绩不同,则按成绩降序排序;如果成绩相同,则按年龄升序排序;如果成绩和年龄都相同,则按姓名的字典顺序排序。最后,我们使用Collections.sort方法来对学生列表进行排序。
阅读全文