Java基础系列-一文搞懂自定义排序

java自定义排序

自定义排序的理解:

我们首先看需求:一个二维数组

\[1,3\],\[8,10\],\[15,18\],\[2,6\]

我们的需求是根据集合(二维数组取出来的数据)

左边小的左边这种方式排序

例如1<8 排序方式就是1,3,8,10

此时我们就需要自定义排序

java 复制代码
intervals={{1,3},{8,10},{15,18},{2,6}};

Arrays.sort(intervals,new Comparator<int[]>()

{

public int compare(int[]s1,int []s2)

{

return s1[0]-s2[0];

}



})

这段代码这样理解 comparator是比较器 是一个接口

我们使用匿名内部类方法 new 一个比较器 这时候必须实现里面的方法 compare方法返回值是Int

我们需要比较的对象是数组 根据数组左边的元素大小来排序

这时候参数就是int\[\]s1,int\[\]s2

实现compare方法

如果s1比s2大 返回就是1 那么 s1就排在后面

我们需要记住备操作的永远是第一个传参进来的数

例如我们在compare里面写

java 复制代码
public int compare(int[]s1,int []s2)

{

return s2[0]-s1[0];

}

此时如果s1大于s2返回值是 负一 那么s1就会排在前面

这一点理解非常重要

如果不熟悉匿名内部类的同学

也可以自定义类实现Comparator接口的compare方法

然后传参给Arrays.sort的第二个参数

例如

java 复制代码
class mycomparator implements Comparator<int[]>
{
public int compare()
{
定义你要实现比较的方法;
}



}

Arrays.sort(需要排序的数据,new mycomparator());
//就可以啦

还有一点就是多重数组可能给大家搞混 永远记住

\[\]\[\] \[\]\[\]这类【】【】的从外到内的数字 也是数组从外到内的过程。

例如

java 复制代码
arr[1][0];//二位数组里面第二个数组的第一个数字
相关推荐
像我这样帅的人丶你还40 分钟前
Java 后端详解(三):全局异常处理与 JPA 数据库映射
java·后端
NE_STOP1 小时前
vibe Coding -- 小项目实战
java
未秃头的程序猿7 小时前
Java 26正式发布!这3个新特性,让代码量直接减半
java·后端·面试
用户298698530147 小时前
Word 文档文本查找与替换的 Java 实现方案
java·后端
阿哉7 小时前
Nacos 服务发现源码:藏在背后的两套事件机制,90%的人只讲了一半
java
咖啡八杯7 小时前
GoF设计模式——命令模式
java·设计模式·架构
AI人工智能_电脑小能手7 小时前
【大白话说Java面试题 第125题】【并发篇】第25题:说说 Java 线程的中断机制
java·后端·面试
Java内核笔记8 小时前
Spring Security 源码解析(六)无状态 JWT 实践:Session 共享与自定义过滤器
java·后端
荣码8 小时前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑
java·python
唐青枫9 小时前
Java 虚拟线程实战指南:从 Thread API 到 Spring Boot 高并发应用
java