标签:tree int scan 构造 比较 引用 演示 显示 案例
/**7,遍历TreeSet集合打印每一个Student对象**/
public void anli() {
//2,键盘录入需要Scanner,创建键盘录入对象
Scanner sc = new Scanner(System.in);
System.out.println("请输入学生成绩格式是:姓名,语文成绩,数学成绩,英语成绩");
//3,创建TreeSet集合对象,在TreeSet的构造函数中传入比较器,按照总分比较
TreeSet<Student> ts = new TreeSet<>(new Comparator<Student>() {
@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 chiness = 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], chiness, math, english));
}
//7,遍历TreeSet集合打印每一个Student对象
System.out.println("排序后的学生信息:");
for (Student t : ts) {
System.out.println(t);
}
}```
标签:tree int scan 构造 比较 引用 演示 显示 案例
原文地址:http://blog.51cto.com/357712148/2298690