自学内容网 自学内容网

《从C/C++到Java入门指南》- 15. Arrays.sort() JDK接口的使用

Arrays.sort() JDK接口的使用

上节学习了 Array.sort() 这个接口,但是我个人不满足于简单的正向排序,我需要一个自定义的排序,怎么弄呢?

自定义范围

需要自定义数组范围可以在第二和第三个参数中传入索引,需要注意的是第二个索引是开区间。

import java.util.Arrays;
public class Main {
    public static void main(String[] args) {
    int[] ns = new int[] {5, 4, 3, 2, 1};
    Arrays.sort(ns, 2, ns.length);// ns.length 不参与排序
    System.out.println(Arrays.toString(ns));
    }
}

自定义规则

我们也可以和C++一样,自定义比较器。

import java.util.*;
public class Main {
    public static void main(String[] args) {
    Integer[] ns = new Integer[] {2, 87, 24, 45, 23, 13, 14, 156, 89};
    Arrays.sort(ns, new Comparator<Integer>() {
    public int compare(Integer a, Integer b) {
    return b - a;
    }
    });
    System.out.println(Arrays.toString(ns));
    }
}

这里用到的重构方法还是很熟悉的,但是这里的Integer有点意思,其实是一个将int包装后的类。

也可以使用一种更简单的方法:

import java.util.*;
public class Main {
    public static void main(String[] args) {
    Integer[] ns = new Integer[] {2, 87, 24, 45, 23, 13, 14, 156, 89};
    Arrays.sort(ns, (a, b) -> {
    return b - a;
    // b - a 大于零的放在前面
    });
    System.out.println(Arrays.toString(ns));
    }
}

当然还有一种方法,但是不过多讨论了,这里直接复制粘贴过来。

import java.util.*;

public class Main {
    public static void main(String[] args){
        Integer[] arr = {5,4,7,9,2,12,54,21,1};
        //降序
        //重新实现Comparator接口
        Arrays.sort(arr, new compa());
        System.out.println(Arrays.toString(arr));
    }
}

class compa implements Comparator<Integer>{

    @Override
    public int compare(Integer o1, Integer o2) {
    // A.compareTo(B) A>B 返回1,A=B 返回0,A<B 返回-1
      // compareTo()返回值>0就交换
      // 如果02 > o1 就交换 =>降序
        return o2.compareTo(o1);
    }
}


原文地址:https://blog.csdn.net/2301_79640368/article/details/140545078

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!