IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> Java中的Comparable 和 Comparator接口 -> 正文阅读

[Java知识库]Java中的Comparable 和 Comparator接口

????????Leetcode刷题时想用优先队列解决,在使用时碰到了怎么排序的问题。我首先给自定义的类Node81实现Comparator接口,重写了接口中的 compare() 方法。
然后定义了一个优先队列 PriorityQueue queue = new PriorityQueue<>();,代码如下,然后运行时就报错啦。

class Node81 implements Comparator<Node81>{
    int row;
    int count;
    
    Node81(){}

    Node81(int row, int count) {
        this.row = row;
        this.count = count;
    }

    @Override
    public int compare(Node81 o1, Node81 o2) {
        if (o1.count > o2.count) {
            return 1;
        }
        if (o1.count < o2.count) {
            return -1;
        }
        return o1.row > o2.row ? 1 : -1;
    }
}

    public int[] kWeakestRows(int[][] mat, int k) {
        PriorityQueue<Node81> queue = new PriorityQueue<>();
        int n = mat.length, m = mat[0].length;
        for (int i = 0; i < mat.length; i++) {
            int count = 0;
            for (int j = 0; j < mat[i].length; j++) {
                if (mat[i][j] == 1) {
                    ++count;
                }
            }
            Node81 node81 = new Node81(i, count);
            queue.add(node81);
        }
        int[] ans = new int[k];

        for (int i = 0; i < k; i++) {
            Node81 remove = queue.remove();
            ans[i] = remove.row;
        }
        return ans;
    }

在这里插入图片描述

?????经过调试后,发现这里我犯了一个低级错误,我虽然实现了Comparator接口,但是在申明初始化优先队列( PriorityQueue queue = new PriorityQueue<>();)的时候并没有将比较器传进去,所以在优先队列添加节点时,因为 compartor 为空会进入 下图中的 siftUpComparable() 方法,因为我没有给Node81类实现 **Comparable **接口中的 compareTo() 方法,就会报上图中的错误。
在这里插入图片描述

Comparable 接口

public interface Comparable<T> {   
    /**
    * 返回 1 :表示比 o 大
    * 返回 -1 :表示比 o 小
    * 返回 0 :表示和 o 相等
    */
    public int compareTo(T o);
}

? ? ? ?可以看到,该接口中其实就只有一个 compareTo(T o) 的方法,将此对象与指定的对象进行顺序比较。Comparable表示可被排序的,实现该接口的类的对象自动拥有排序功能,像Collections.sort()或Arrays.sort可以直接对游该类组成的数组或者集合进行排序.

Comparator 接口

@FunctionalInterface
public interface Comparator<T> {
    int compare(T o1, T o2);
  
    boolean equals(Object obj);
    
    // 1.8 后有很多新增的默认方法
}

? ? ? ?Comparator是比较器,它可以作为一个参数传递到Collections.sort和Arrays.sort方法等来指定某个类对象的排序方式。像优先队列就可以在初始化的时候给其传递一个实现了Camparator接口的类。如下方代码所示。

	// 只要是实现了Comparator的接口都行
    public PriorityQueue(Comparator<? super E> comparator) {
        this(DEFAULT_INITIAL_CAPACITY, comparator);
    }

? ? ? ?所以我开始给优先队列初始化应该给其加上参数:PriorityQueue queue = new PriorityQueue<>(new Node81()); 这样优先队列就会识别到有比较强而不去找compareTo() 方法。从这里也可以看出:当Comparable和Comparator接口都实现了的时候,会优先使用Comparator接口的 compare() 方法来进行排序。

总结

  • Comparable接口和Comparator的功能都差不多,都是给类排序
  • Comparable是让类能够像基础数据一样自然排序,Comparator在使用时需要将其作为参数传递进去
  • 当Comparable和Comparator接口同时都实现了的时候,会优先使用Comparator接口的排序规则
  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-08-02 10:40:39  更:2021-08-02 10:42:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年4日历 -2025/4/12 3:08:04-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码