/**
* 集合存储学生类(有姓名和成绩两个属性),
* 按照姓名由前到后、成绩由低到高的顺序输出
*/
import java.util.*;
public class LinkedStudentDemo {
public static void main(String[] args) {
Set<Student> set = new TreeSet<>(new Comparator<Student>() {
@Override
public int compare(Student o1, Student o2) {
//姓名由前到后自然输出
if (o1.name.compareTo(o2.name)==0) {
//姓名相同成绩由低到高输出
Integer first=Integer.valueOf(o1.score);
Integer second=Integer.valueOf(o2.score);
return (first.compareTo(second));
}else {//姓名不同的情况下按照姓名从上往下排序
return o1.name.compareTo(o2.name);
}
}
});
Student s1 = new Student("zhangsan", 100);
Student s2 = new Student("lisi", 90);
Student s3 = new Student("wangwu", 80);
Student s4 = new Student("zhaoliu", 70);
Student s5 = new Student("liuqi", 100);
Student s6 = new Student("zhouba", 80);
set.add(s1);// 添加元素
set.add(s2);
set.add(s3);
set.add(s4);
set.add(s5);
set.add(s6);
for (Student student : set) {
System.out.println(student);
}
}
}
// 定义一个学生类
class Student {
int score;
String name;
// 构造函数
public Student(String name, int score) {
super();
this.score = score;
this.name = name;
}
@Override // 方法的重写
public String toString() {
return "Student [score=" + score + ", name=" + name + "]";
}
}