练习:写一个学生类,属性有学号,姓名,性别,年龄,创建5个学生对象,给学生按照年龄排序,如果年龄一样,按照学号排序.
先创建comparator 接口 进行比较器
代码如下
import java.util.TreeSet;
import java.util.Comparator;
public class TestTreeset {
public static void main(String[] args) {
// MyComparator myComparator = new MyComparator();
// TreeSet treeSet = new TreeSet(myComparator);
Mycomparator mycomparator = new Mycomparator();
TreeSet treeSet = new TreeSet(mycomparator);
Student9 s1 = new Student9("到大", "男", 13, 10);
Student9 s2 = new Student9("搜索", "男", 45, 15);
Student9 s3 = new Student9("ff", "女", 18, 8);
treeSet.add(s1);
treeSet.add(s2);
treeSet.add(s3);
System.out.println(treeSet);
}
}
class Student9{
private String name;
private String sex;
private int number;
private int age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public int getNumber() {
return number;
}
public void setNumber(int number) {
this.number = number;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "Student9 [name=" + name + ", sex=" + sex + ", number=" + number + ", age=" + age + "]";
}
public Student9(String name, String sex, int number, int age) {
super();
this.name = name;
this.sex = sex;
this.number = number;
this.age = age;
}
}
class Mycomparator implements Comparator<Student9>{
@Override
public int compare(Student9 o1, Student9 o2) {
// TODO Auto-generated method stub
if(o1.getAge()-o2.getAge()==0){
return o1.getNumber()-o2.getNumber();//从小到大
}
else{
return o1.getAge()-o2.getAge();
}
}
}
本文介绍了一个使用Java实现的学生类,并通过TreeSet与自定义比较器对学生对象按年龄和学号进行排序的例子。
594

被折叠的 条评论
为什么被折叠?



