import java.util.*;
/*
3.分别用Comparable和Comparator两个接口对下列四位同学的成绩做降序排序,如果成绩一样,
那在成绩排序的基础上按照年龄由小到大排序。
姓名(String)年龄(int)分数(float)
liusan 20 90.0F
lisi 22 90.0F
wangwu 20 99.0F
sunliu 22 100.0F
编写一个Student类用来实现Comparable<Student>接口,并在其中重写CompareTo(Student o)方法
在主函数中使用Comparable 与 Comparetor分别对ArrayList进行排序.
*/
public class Test04 {
public static void main(String[] args) {
ArrayList<Student2> list = new ArrayList<>();
list.add(new Student2("lisi",22,90.0F));
list.add(new Student2("liusan",20,90.0F));
list.add(new Student2("sunliu",22,100.0F));
list.add(new Student2("wangwu",20,99.0F));
TreeSet<Student2> tr = new TreeSet<>(new StudentComparator());//传入构造器
tr.addAll(list); //通过addAll方法把ArrayList集合中的元素加到TreeSet集合中
/* //也可以使用匿名内部类的形式,使用后StudentComparator类不用写了
集合例题2.2:分别用Comparable和Comparator两个接口对下列四位同学的成绩做降序排序,如果成绩一样,那在成绩排序的基础上按照年龄由小到大排序。姓名(String)年龄
本文展示了如何使用Comparable接口和Comparator接口对四名学生的成绩和年龄进行排序,首先根据分数降序,分数相同时再按年龄升序。实例中创建了Student2类实现了Comparable,并在主函数中使用这两种方式对ArrayList进行操作。
摘要由CSDN通过智能技术生成