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];//二位数组里面第二个数组的第一个数字 ```

相关推荐
lkbhua莱克瓦2417 小时前
基础-函数
开发语言·数据库·笔记·sql·mysql·函数
清水白石00817 小时前
《深入 Python 上下文管理器:contextlib.contextmanager 与类实现方式的底层差异全景解析》
开发语言·python
程序员佳佳17 小时前
GPT-4时代终结?GPT-5.2与Banana Pro实测数据公开,普通开发者如何接住这泼天富贵
开发语言·python·gpt·chatgpt·重构·api·midjourney
tbRNA17 小时前
Java 基础入门易错知识点(三)
java·开发语言
韩立学长17 小时前
【开题答辩实录分享】以《基于SSM的电影售票管理系统的设计与实现》为例进行选题答辩实录分享
java·spring·servlet
问道飞鱼17 小时前
【Rust编程语言】Rust数据类型全面解析
开发语言·后端·rust·数据类型
会飞的胖达喵18 小时前
Qt自动信号槽连接机制:深入解析与应用实践
开发语言·qt
无奈笑天下18 小时前
银河麒麟V10虚拟机安装vmtools报错:/bin/bash解释器错误, 权限不够
linux·运维·服务器·开发语言·经验分享·bash
superman超哥18 小时前
仓颉动态特性探索:反射API的原理、实战与性能权衡
开发语言·后端·仓颉编程语言·仓颉·仓颉语言·仓颉动态特性·反射api
程序员阿鹏18 小时前
@Autowired和@Resource的区别
java·开发语言·spring