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));
    }
}
相关推荐
一只齐刘海的猫11 分钟前
【Leetcode】找到字符串中所有字母异位词
算法·leetcode·职场和发展
海清河晏11133 分钟前
数据结构 | 八大排序
数据结构·算法·排序算法
liulilittle1 小时前
固定数组时间轮的槽过载优化:桶链表与批次执行
网络·数据结构·链表
IronMurphy2 小时前
【算法五十七】146. LRU 缓存
算法·缓存
Irissgwe2 小时前
数据结构-栈和队列
数据结构·c++·c·栈和队列
两片空白2 小时前
数据容器集合set/frozenset
数据结构
凌波粒2 小时前
LeetCode--108.将有序数组转换为二叉搜索树(二叉树)
算法·leetcode·职场和发展
liulilittle2 小时前
KCC:在 BBR 思路上的一次探索
网络·tcp/ip·算法·bbr·通信·拥塞控制·kcc
浦信仿真大讲堂3 小时前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍
人工智能·python·算法·仿真软件·达索软件
点云侠3 小时前
PCL 生成三棱锥点云
c++·算法·最小二乘法