集合练习题(3)

3.分别用Comparable和Comparator两个接口对下列四位同学的成绩做降序排序,如果成绩一样,
那在成绩排序的基础上按照年龄由小到大排序。

姓名(String) 年龄(int) 分数(float)
liusan 20 90.0F
lisi 22 90.0F
wangwu 20 99.0F
sunliu 22 100.0F

编写一个Student类用来实现Comparable接口,并在其中重写CompareTo(Student o)方法

在主函数中使用Comparable 与 Comparetor分别对ArrayList进行排序.

package allTest;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

/**
 *
 3.分别用Comparable和Comparator两个接口对下列四位同学的成绩做降序排序,如果成绩一样,
 那在成绩排序的基础上按照年龄由小到大排序。

 姓名(String)		年龄(int)			分数(float)
 liusan			20				90.0F
 lisi			22				90.0F
 wangwu			20				99.0F
 sunliu			22				100.0F

 编写一个Student类用来实现Comparable<Student>接口,并在其中重写CompareTo(Student o)方法 

 在主函数中使用Comparable 与 Comparetor分别对ArrayList进行排序.
 */
public class Test03 {
    public static void main(String[] args) {
        //创建对象
        Student s1 = new Student("liusan",20,90);
        Student s2 = new Student("lisi",22,90);
        Student s3 = new Student("wangwu",20,99);
        Student s4 = new Student("sunliu",22,100);
        //创建ArrayList集合

        List<Student> l1 = new ArrayList<>();
        //添加元素
        l1.add(s1);
        l1.add(s2);
        l1.add(s3);
        l1.add(s4);

        //LIst必须使用这句话进行排序一下,我吐了。
        Collections.sort(l1);

       /*

       Comparator方法!!
       Collections.sort(l1, new Comparator<Student>() {
            @Override
            public int compare(Student o1, Student o2) {
                if (o1.score-o2.score==0){
                    return o1.age-o2.age;
                }else{
                    return o2.score-o1.score;
                }
            }
        });*/
        //遍历
        for (Student p:
             l1) {
            System.out.println(p);
        }
    }
}
class  Student implements Comparable<Student>{
    String name;
    int age;
    int score;

    public Student() {
    }

    public Student(String name, int age, int score) {
        this.name = name;
        this.age = age;
        this.score = score;
    }


    public int compareTo(Student o) {

//        对下列四位同学的成绩做降序排序,如果成绩一样,
//        那在成绩排序的基础上按照年龄由小到大排序。

        if (this.score-o.score==0){
            return this.age-o.age;
        }else{
            return o.score-this.score;
        }

    }

    @Override
    public String toString() {
        return "学生{" +
                "姓名='" + name + '\'' +
                ", 年龄=" + age +
                ", 分数=" + score +
                '}';
    }
}
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值