Lambda + Arrays---小练习

题目

按照要求进行排序

定义数组并存储一些学生对象,利用 Arrays 中的 sort 方法进行排序

要求 1:属性有姓名、年龄、身高。

要求 2:按照年龄的大小进行排序,年龄一样,按照身高排序,身高一样按照姓名的字母进行排序。

思路

利用之前提到的Arrays.sort底层逻辑来实现排序:自定义对象数组的多级排序,按照年龄、身高、姓名依次排序,注意:在sort方法中,o1-o2是升序、o2-o1是降序,因为sort底层逻辑是插入排序+二分查找,拿未排序数组的元素和已排序数组的元素进行比较,若o1-o2是正数表示当前插入元素是大的,放在已排好序数组元素的后面,0表示插入元素和现在比是一样的,也放在后面,负数表示当前插入元素是小的,放在前面

代码

这里给大家写了两种方式:匿名内部类、Lambda

对象类:

java 复制代码
public class Student {
    private String name;
    private int age;
    private double height;

    public Student() {
    }

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

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public double getHeight() {
        return height;
    }

    public void setHeight(double height) {
        this.height = height;
    }

    @Override
    public String toString() {
        return "Student{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", height=" + height +
                '}';
    }
}

实现类:

java 复制代码
import java.util.Arrays;
import java.util.Comparator;

public class test1 {
    public static void main(String[] args) {
        
        //compareTo方法来比较字符串大小
        Student gf1=new Student("z",18,1.68);
        Student gf2=new Student("y",18,1.69);
        Student gf3=new Student("l",19,1.70);

        Student[] arr={gf1,gf2,gf3};

        Arrays.sort(arr, new Comparator<Student>() {
            @Override
            public int compare(Student o1, Student o2) {
                //按照年龄大小排序,年龄一样按身高排序,身高一样按照姓名的字母排序
                double temp=o1.getAge()- o2.getAge();
                temp=temp==0?o1.getHeight()-o2.getHeight():temp;
                temp=temp==0?o1.getName().compareTo(o2.getName()):temp;

               
                if(temp>0){
                    return 1;
                }else if(temp<0){
                    return -1;
                }else{
                    return 0;
                }
            }
        });

        //Lambda表达式
        Arrays.sort(arr, (Student o1, Student o2)->{
                //按照年龄大小排序,年龄一样按身高排序,身高一样按照姓名的字母排序
                double temp=o1.getAge()- o2.getAge();
                temp=temp==0?o1.getHeight()-o2.getHeight():temp;
                temp=temp==0?o1.getName().compareTo(o2.getName()):temp;

                if(temp>0){
                    return 1;
                }else if(temp<0){
                    return -1;
                }else{
                    return 0;
                }
            }
        );

        //Lambda极简表达式
        Arrays.sort(arr, ( o1, o2)->{
                    //按照年龄大小排序,年龄一样按身高排序,身高一样按照姓名的字母排序
                    double temp=o1.getAge()- o2.getAge();
                    temp=temp==0?o1.getHeight()-o2.getHeight():temp;
                    temp=temp==0?o1.getName().compareTo(o2.getName()):temp;

               
                    if(temp>0){
                        return 1;
                    }else if(temp<0){
                        return -1;
                    }else{
                        return 0;
                    }
                }
        );

        System.out.println(Arrays.toString(arr));
    }
}
相关推荐
平行侠1 分钟前
A15 工业路由器IP前缀高速检索与内存压缩系统
网络·tcp/ip·算法
阿旭超级学得完1 小时前
C++11包装器(function和bind)
java·开发语言·c++·算法·哈希算法·散列表
li星野1 小时前
位运算 & 数学 & 高频进阶九题通关(Python + C++)
c++·python·学习·算法
jerryinwuhan1 小时前
hello算法,简单讲(1)
算法·排序算法
y = xⁿ1 小时前
20天速通LeetCodeday15:BFS广度优先搜索
算法·宽度优先
400分1 小时前
吃透RAG核心-----语义检索与关键字检索底层原理
算法·架构
目黑live +wacyltd2 小时前
算法备案:常见驳回原因与应对策略
人工智能·算法
磊 子2 小时前
多态类原理+四种类型转换+异常处理
开发语言·c++·算法
染指11103 小时前
3.AI大模型-token是什么-大模型底层运行机制
人工智能·算法·机器学习
谙弆悕博士4 小时前
快速学C语言——第19章:C语言常用开发库
c语言·开发语言·算法·业界资讯·常用函数