集合存储学生类(有姓名和成绩两个属性), 按照姓名由前到后、成绩由低到高的顺序输出

该博客展示了如何使用Java集合中的TreeSet,根据学生姓名的字母顺序和成绩的高低进行排序。通过创建自定义Comparator实现比较规则,先按姓名升序,若姓名相同则按成绩降序排列。示例代码中创建了多个Student对象,并添加到TreeSet中,最终按照设定的排序规则输出所有学生信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


/**
 * 集合存储学生类(有姓名和成绩两个属性),
 * 按照姓名由前到后、成绩由低到高的顺序输出 
 */
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 + "]";
}


}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值