java中的Arrays.sort()排序方法

这篇具有很好参考价值的文章主要介绍了java中的Arrays.sort()排序方法。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一、方法重载

二、注意事项

 三、举例

(1)对于基本数据类型的数组,排序时会按照升序排序;

(2)对对象数组进行排序


Java中的Arrays.sort()方法是一种内置的排序方法,用于对数组进行排序。这是一个来自java.util.Arrays类的静态方法,用于对所有的基本数据类型对象数组以及对象数组进行排序。排序的默认顺序是升序。

一、方法重载

Arrays.sort()方法有许多重载版本,可以接受不同类型的输入,并对它们进行排序。以下是一些常见的重载版本:

  • Arrays.sort(byte[] a): 对字节型数组进行排序
  • Arrays.sort(char[] a): 对字符型数组进行排序
  • Arrays.sort(double[] a): 对双精度浮点型数组进行排序
  • Arrays.sort(float[] a): 对浮点型数组进行排序
  • Arrays.sort(int[] a): 对整型数组进行排序
  • Arrays.sort(long[] a): 对长整型数组进行排序
  • Arrays.sort(short[] a): 对短整型数组进行排序
  • Arrays.sort(Object[] a): 对对象数组进行排序,此方法要求数组中的对象必须实现了Comparable接口
  • Arrays.sort(T[] a, Comparator<? super T> c): 对对象数组进行排序,使用一个定制的Comparator对象来比较数组中的元素

二、注意事项

  1. 对于对象数组,如果使用默认的Arrays.sort(Object[] a)方法进行排序,那么数组中的对象必须实现了Comparable接口。如果对象没有实现这个接口,那么在运行时会抛出ClassCastException

  2. Arrays.sort(T[] a, Comparator<? super T> c)这个版本的方法允许你传入一个Comparator对象来自定义排序的规则。如果传入的Comparator对象为null,那么此方法将会使用元素的自然顺序进行排序。

  3. 对于对象数组的排序,Arrays.sort()方法使用的是稳定的排序算法,这意味着等值的元素在排序后会保持他们原有的相对位置。

  4. Arrays.sort()方法的时间复杂性为O(n log n)。

  5. Arrays.sort()方法会对输入的数组进行直接排序,也就是说,它会改变输入数组的元素顺序。如果不希望改变原数组的元素顺序,那么在排序前需要先对数组进行复制。

 三、举例

(1)对于基本数据类型的数组,排序时会按照升序排序;

int[] arr = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5};
Arrays.sort(arr); // 对数组进行排序

for (int i = 0; i < arr.length; i++) {
    System.out.print(arr[i] + " ");
}

输出结果:

1 1 2 3 3 4 5 5 5 6 9

ps:Arrays.sort() 方法使用的是快速排序算法和归并排序算法,具体使用哪一种算法取决于数组的大小和类型。当数组长度小于 Arrays.MIN_ARRAY_SORT_GRAN 时,使用插入排序算法对其进行排序。

(2)对对象数组进行排序

可以通过实现 Comparator 接口来指定比较器对象。Comparator 接口需要实现 compare() 方法,该方法接受两个对象作为参数,并返回一个整数值,用于表示这两个对象的大小关系。如果返回的值为负数,则表示第一个对象小于第二个对象,为正序;如果返回的值为正数,则表示第一个对象大于第二个对象,为逆序;如果返回的值为0,则表示两个对象相等。

import java.util.*;

class Person {
    private String name;
    private int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public int getAge() {
        return age;
    }
}

class PersonAgeComparator implements Comparator<Person> {
    @Override
    public int compare(Person o1, Person o2) {
        return o1.getAge() - o2.getAge();
    }
}

public class Main {
    public static void main(String[] args) {
        Person[] people = {
                new Person("Alice", 25),
                new Person("Bob", 20),
                new Person("Charlie", 30)
        };

        Arrays.sort(people, new PersonAgeComparator());

        for (Person p : people) {
            System.out.println(p.getName() + " " + p.getAge());
        }
    }
}

输出结果

Bob 20
Alice 25
Charlie 30

在该示例中,定义了一个 Person 类,包含两个属性 name 和 age。按照年龄对 Person 对象数组进行排序,创建了一个 PersonAgeComparator 类,实现了 Comparator 接口,并重写了 compare() 方法。在  main() 方法中,调用 Arrays.sort() 方法,并入 PersonAgeComparator 对象,来对 Person 对象数组进行排序。文章来源地址https://www.toymoban.com/news/detail-716686.html

到了这里,关于java中的Arrays.sort()排序方法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • arrays.sort用法详解

    大家好,我是免费搭建查券返利机器人赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!在编程的世界中,数组(arrays)是一种常见且重要的数据结构,而在Java中,对数组进行排序是经常遇到的需求之一。今天,我们将深入探讨Java中的 Arrays

    2024年02月04日
    浏览(32)
  • 【Java基础教程】(三十八)常用类库篇 · 第八讲:数组操作类——解析Arrays类中的全部操作方法,解锁Java数组操作技巧~

    前言:在学习本文之前,应该先学习并清楚了解Java基础部分的数组相关的概念和知识。 若还不具备学习条件,请先前往学习数组部分的基础知识: 《【Java基础教程】(八)面向对象篇 · 第二讲:Java 数组全面解析——动态与静态初始化、二维数组、方法参数传递、排序与转

    2024年02月15日
    浏览(47)
  • leetcode Median of Two Sorted Arrays

    Given two sorted arrays  nums1  and  nums2  of size  m  and  n  respectively, return  the median  of the two sorted arrays. The overall run time complexity should be  O(log (m+n)) . Example 1: Example 2: Constraints: nums1.length == m nums2.length == n 0 = m = 1000 0 = n = 1000 1 = m + n = 2000 -106 = nums1[i], nums2[i] = 106

    2023年04月08日
    浏览(32)
  • 聊聊 Java 集合框架中的Arrays

    Arrays 和 Collections 是分别操作数组和集合的两个工具类。今天就来对 Arrays 中的内容作个总结。 Arrays 类位于 java.util 包中。 Arrays 继承 Object Arrays 类中的静态方法可以对数组进行排序、查询、搜索等等操作。 1. Arrays.asList() 方法描述 该方法返回一个 ArrayList , 其返回的 ArrayList

    2024年01月21日
    浏览(38)
  • LeetCode //C - 4. Median of Two Sorted Arrays

    Given two sorted arrays nums1 and nums2 of size m and n respectively, return the median of the two sorted arrays. The overall run time complexity should be O(log (m+n)) .   Example 1: Input: nums1 = [1,3], nums2 = [2] Output: 2.00000 Explanation: merged array = [1,2,3] and median is 2. Example 2: Input: nums1 = [1,2], nums2 = [3,4] Output: 2.50000 Explanati

    2024年02月06日
    浏览(27)
  • Java数组中Arrays.fill()方法讲解

    fill()方法共有两种参数类型,分别是: (1)Arrays.fill(int[] a,int value)            a :要进行替换元素的数组            value :替换的元素值 (2)Arrays.fill(int[] a,int fromIndex,int toIndex,int value)            a :要进行替换元素的数组            fromIndex :需要替换元素的第

    2024年02月12日
    浏览(36)
  • Java 浅谈数组(Array)和列表(ArrayList)的区别 介绍Arrays常用方法

    目录 一.数组和列表的区别 1.数组(Array) (1)数组(Array) (2)数组的声明与创建 (3)多维数组 (4)数组的优缺点 2.列表(ArrayList) (1)列表(ArrayList) (2)列表的声明与创建 (3)列表的优缺点 3.数组(Array)与列表(ArrayList)的区别 (1)空间大小 (2)存储内容

    2023年04月09日
    浏览(36)
  • Java中合并两个数组的4种方法(How to Merge Two Arrays in Java)

    int[] arr1={1, 2, 3, 4, 5, 6}; //first array int[] arr2={7, 8, 9, 0}; //second array int[] arr3={1, 2, 3, 4, 5, 6, 7, 8, 9, 0} //resultant array There are following ways to merge two arrays: 1.Java arraycopy() method 2.Without using arraycopy() method 3.Java Collections 4.Java Stream API Java arraycopy() is the method of System class which belongs to java.la

    2024年02月11日
    浏览(31)
  • 数据结构与算法中的七大排序(Java实现)

    目录 一、直接插入排序 二、希尔排序 三、直接选择排序 四、堆排序 五、冒泡排序 六、快速排序 七、归并排序               定义i下标之前的元素全部已经有序 ,遍历一遍要排序的数组,把i下标前的元素全部进行排序,当遍历玩这个数组后,就已经排好序了。        

    2024年02月06日
    浏览(42)
  • Arrays.asList()方法 讲解

    ✨作者:猫十二懿 ❤️‍🔥账号:CSDN 掘金 个人博客 Github 🎉公众号:猫十二懿 Arrays.asList()是一个Java数组与集合之间的桥梁方法,它可以将一个数组转换为一个List集合。使用Arrays.asList()方法,我们可以将一个数组转换为一个List集合,然后使用List的方法来操作这个集合,比

    2024年02月15日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包