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

作者:再美不及姑娘你 时间:2023-10-16 01:37:24 

需求: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());
       }
   }
}

来源:https://www.cnblogs.com/CYan521/p/16073313.html

标签:Java,使用,排序器,comparator,成绩,排序
0
投稿

猜你喜欢

  • 详解kafka中的消息分区分配算法

    2021-06-02 08:16:15
  • java多线程之CyclicBarrier的使用方法

    2023-11-04 21:52:54
  • Java+Nginx实现POP、IMAP、SMTP邮箱代理服务

    2023-11-26 10:31:47
  • C#内置队列类Queue用法实例

    2023-07-18 14:12:05
  • C#中Convert.ToString和ToString的区别分析

    2023-02-04 22:18:06
  • resty upload无需依赖的文件上传与下载

    2023-01-17 14:54:31
  • JDK1.8下载、安装和环境配置超详细教程(最新最完整)

    2022-07-22 12:58:34
  • java实现人员信息管理系统

    2023-11-02 05:21:31
  • Java通过Scanner了解if...else if语句

    2023-11-29 04:28:44
  • Java工具类DateUtils实例详解

    2022-08-22 00:40:35
  • Android实现自定义轮播图片控件示例

    2021-09-19 01:27:05
  • C# SQlite操作方法小结

    2021-10-01 15:56:09
  • Android在JNI中使用ByteBuffer的方法

    2021-11-08 21:14:35
  • Android 暂停和恢复Activity

    2021-07-09 06:33:18
  • 使用OpenGL绘制Bezier曲线

    2023-03-14 19:55:39
  • Java 数据结构与算法系列精讲之KMP算法

    2023-05-06 14:55:55
  • springboot 按月分表的实现方式

    2023-11-25 00:03:47
  • java判断字符串是否有逗号的方法

    2021-11-03 08:01:23
  • Java Servlet简单实例分享(文件上传下载demo)

    2022-03-03 06:35:04
  • java精度计算代码 java指定精确小数位

    2023-07-31 03:03:58
  • asp之家 软件编程 m.aspxhome.com