欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

Java案例使用比较排序器comparator实现成绩排序

时间:2022-09-27 11:11:42|栏目:JAVA代码|点击:

需求:TreeSet集合存储多个学生信息(姓名,语文成绩,数学成绩),并遍历该集合;要按照总分从高到低进行排序

分析:

  • 1.创建学生类 成员变量 姓名,语文成绩、数学成绩;成员方法 求总分;构造方法 无参构造,带参构造; get\set方法
  • 2.创建测试类
  • 3.创建TreeSet集合对对象,并使用内部类的方式重写compare方法

要定好排序规则,主要条件按照总分从高到底排序,在总分相同的情况下按照语文成绩排序,在两者都相同的情况下判断姓名是否相同,相同就不存储,不相同存进来,按照姓名字母进行排序

  • 4.创建学生对象,并使用带参构造添加学生数据
  • 5.使用add方法将学生数据加入到TreeSet集合中
  • 6.进行遍历

代码实现:

Student类

public class Student {
    //成员变量
    private String  name;
    private int YWscore;
    private int YYscore;
?
    //构造方法
    public Student(){}
?
    public Student(String name, int YWscore, int YYscore) {
        this.name = name;
        this.YWscore = YWscore;
        this.YYscore = YYscore;
    }
    //get/set方法
?
    public String getName() {
        return name;
    }
?
    public void setName(String name) {
        this.name = name;
    }
?
    public int getYWscore() {
        return YWscore;
    }
?
    public void setYWscore(int YWscore) {
        this.YWscore = YWscore;
    }
?
    public int getYYscore() {
        return YYscore;
    }
?
    public void setYYscore(int YYscore) {
        this.YYscore = YYscore;
    }
    //定义求总成绩方法
    public int getSum(){
        int sum=YWscore+YYscore;
        return sum;
    }
}
?

测试类

public class StudentDemo {
    public static void main(String[] args) {
        //创建TreeSet集合对象
        TreeSet<Student>ts=new TreeSet<Student>(new Comparator<Student>() {
            @Override
            public int compare(Student s1, Student s2) {
//                return 0;
                int num=s2.getSum()-s1.getSum();//要从高到底排序
                int num1= num==0?s1.getYWscore()-s2.getYWscore():num;//当总分相同时按照语文成绩排序
                int num2= num1==0?s1.getName().compareTo(s2.getName()):num1;
                return num2;
            }
        });
        //创建学生对象
        Student s1=new Student("张三",56,66);
        Student s2=new Student("张四",70,69);
        Student s3=new Student("张五",80,76);
        Student s4=new Student("张六",66,96);
        Student s5=new Student("张七",66,96);
        ts.add(s5);
        ts.add(s1);
        ts.add(s2);
        ts.add(s3);
        ts.add(s4);
        //遍历
        for (Student ss:ts){
            System.out.println(ss.getName()+","+ss.getYWscore()+","+ss.getYYscore()+","+ss.getSum());
        }
    }
}

上一篇:Java面试题冲刺第二十一天--JVM

栏    目:JAVA代码

下一篇:JavaFx 实现按钮防抖功能

本文标题:Java案例使用比较排序器comparator实现成绩排序

本文地址:http://www.codeinn.net/misctech/214851.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有