黑马程序员 集合框架之TreeSet实例

本文详细介绍了如何使用Java语言和TreeSet集合来实现学生信息的排序功能,通过自定义Comparable接口,使得集合能够按照学生的成绩进行自然排序。包括学生类的设计、接口实现以及排序过程的展示。
               -----------  android培训 java培训 、java学习型技术博客、期待与您交流! ------------
/*
需求: 声明类Student,包含3个成员变量:name、age、score,创建5个对象装入TreeSet,按照成绩排序输出结果(考虑成绩相同的问题)。
分析:TreeSet自身默认的是自然排序,若要按照指定排序,则要让学生具有可比性,或者让集合自身具有可比性,可以有两种方法来实现,实现Comparable接口和利用Comparator比较器。
*/
import java.util.*;
class  TreeSetDemo
{
public static void main(String[] args) 
{
TreeSet<Student> ts = new TreeSet<Student> ();//建立TreeSet容器。
ts.add(new Student("zhangya", 23,76.6));
ts.add(new Student("chengwu", 24,77.6));
ts.add(new Student("lisi", 27,86.6));
ts.add(new Student("zhyu", 23,80.6));
ts.add(new Student("zsdfs", 23,76.6));
Iterator<Student> it = ts.iterator(); // 调用自身方法使用迭代器。
while (it.hasNext())
{
Student temp = it.next();
System.out.println(temp.getName() + " , " + temp.getAge() + " , " + temp.getScore());
}
}

}
class Student implements Comparable<Student>      //  建立Student对象并实现Comparable接口。
{
private String name;
private int age;
private double score;
Student(String name, int age, double score)
{
this.name = name;
this.age = age;
this.score = score;
}
public int compareTo(Student s)    //复写接口里的方法,让学生具有可比性。
{
int num =(int)(new Double(this.score).compareTo(new Double(s.score)));
if(num==0)
num = this.name.compareTo(s.name);
return num;
}
public boolean equals(Object obj)   //复写Object的equals方法。
{
if(!(obj instanceof Student))
throw new ClassCastException("类型不对");
Student st = (Student)obj;
return this.name.equals(st.name)&& this.age == st.age;
}
public int hashCode()          //复写Object的hashCode方法。
{
return name.hashCode() + age * 7;
}
public void setName(String name)
{
this.name = name;
}
public String getName()
{
return name;
}
public void setAge(int age)
{
this.age = age;
}
public int getAge()
{
return age;
}
public void setScore(double score)
{
this.score = score;
}
public double getScore()
{
return score;
}
}

                 -----------  android培训 java培训 、java学习型技术博客、期待与您交流! ------------

标题基于Python的自主学习系统后端设计与实现AI更换标题第1章引言介绍自主学习系统的研究背景、意义、现状以及本文的研究方法和创新点。1.1研究背景与意义阐述自主学习系统在教育技术领域的重要性和应用价值。1.2国内外研究现状分析国内外在自主学习系统后端技术方面的研究进展。1.3研究方法与创新点概述本文采用Python技术栈的设计方法和系统创新点。第2章相关理论与技术总结自主学习系统后端开发的相关理论和技术基础。2.1自主学习系统理论阐述自主学习系统的定义、特征和理论基础。2.2Python后端技术栈介绍DjangoFlask等Python后端框架及其适用场景。2.3数据库技术讨论关系型和非关系型数据库在系统中的应用方案。第3章系统设计与实现详细介绍自主学习系统后端的设计方案和实现过程。3.1系统架构设计提出基于微服务的系统架构设计方案。3.2核心模块设计详细说明用户管理、学习资源管理、进度跟踪等核心模块设计。3.3关键技术实现阐述个性化推荐算法、学习行为分析等关键技术的实现。第4章系统测试与评估对系统进行功能测试和性能评估。4.1测试环境与方法介绍测试环境配置和采用的测试方法。4.2功能测试结果展示各功能模块的测试结果和问题修复情况。4.3性能评估分析分析系统在高并发等场景下的性能表现。第5章结论与展望总结研究成果并提出未来改进方向。5.1研究结论概括系统设计的主要成果和技术创新。5.2未来展望指出系统局限性并提出后续优化方向。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值