java treeset什么意思_JAVA基础(TreeSet总分从高到低输出)

该博客介绍如何利用Java的TreeSet集合和自定义比较器,根据学生的总分从高到低来存储和排序学生信息。通过创建学生类,键盘录入学生数据,并在TreeSet中使用Comparator比较器实现总分的比较。最后遍历并输出排序后的学生信息。
摘要由CSDN通过智能技术生成

1,需求:

键盘录入5个学生信息(姓名,语文成绩,数学成绩,英语成绩),按照总分从高到低输出到控制台。

2,分析:

定义一个学生类

成员变量:姓名,语文成绩,数学成绩,英语成绩,总成绩

成员方法:空参,有参构造,有参构造的参数分别是姓名,语文成绩,数学成绩,英语成绩

toString方法,在遍历集合中的Student对象打印对象引用的时候会显示属性值

键盘录入需要Scanner,创建键盘录入对象

创建TreeSet集合对象,在TreeSet的构造函数中传入比较器,按照总分比较

录入五个学生,所以以集合中的学生个数为判断条件,如果size是小于5就进行存储

将录入的字符串切割,用逗号切割,会返回一个字符串数组,将字符串数组中从二个元素转换成int数,

将转换后的结果封装成Student对象,将Student添加到TreeSet集合中

遍历TreeSet集合打印每一个Student对象

3,代码实现:

import java.util.Comparator;

import java.util.Scanner;

import java.util.TreeSet;

public class Test7 {

public static void main(String[] args) {

//2,键盘录入需要Scanner,创建键盘录入对象

Scanner sc = new Scanner(System.in);

System.out.println("请输入学生成绩格式是:姓名,语文成绩,数学成绩,英语成绩");

//3,创建TreeSet集合对象,在TreeSet的构造函数中传入比较器,按照总分比较

TreeSet ts = new TreeSet<>(new Comparator() {

@Override

public int compare(Student s1, Student s2) {

int num = s2.getSum() - s1.getSum();

return num == 0 ? 1 : num;

}

});

//4,录入五个学生,所以以集合中的学生个数为判断条件,如果size是小于5就进行存储

while(ts.size() < 5) {

//5,将录入的字符串切割,用逗号切割,会返回一个字符串数组,将字符串数组中从二个元素转换成int数,

String line = sc.nextLine();

String[] arr = line.split(",");

int chinese = Integer.parseInt(arr[1]);

int math = Integer.parseInt(arr[2]);

int english = Integer.parseInt(arr[3]);

//6,将转换后的结果封装成Student对象,将Student添加到TreeSet集合中

ts.add(new Student(arr[0], chinese, math, english));

}

//7,遍历TreeSet集合打印每一个Student对象

System.out.println("排序后的学生信息:");

for (Student s : ts) {

System.out.println(s);

}

}

}

bean类public class Student {

private String name;

private int chinese;

private int math;

private int english;

private int sum;

public Student() {

super();

}

public Student(String name, int chinese, int math, int english) {

super();

this.name = name;

this.chinese = chinese;

this.math = math;

this.english = english;

this.sum = this.chinese + this.math + this.english;

}

public int getSum() {

return sum;

}

public String toString() {

return name + "," + chinese + "," + math + "," + english + "," + sum;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值