Array类

文章介绍了Java中Array类的使用,如toString方法打印数组和sort方法进行升序排序。通过示例展示了如何利用Comparator接口进行自定义排序,包括创建匿名内部类实现compare方法,以实现基于特定规则的数组排序。此外,提到了sort方法的底层实现可能采用类似策略。
摘要由CSDN通过智能技术生成

Array类是数组类,其自带的一些方法可以对数组进行操作,能够一定程度上简化开发。

import java.util.Arrays;

public class ArraysDemo {
    public static void main(String[] args) {
        Integer[] integers = {1,2,3};
        int a[] = {1,2,34,7};
        System.out.println(Arrays.toString(integers));
        Arrays.sort(a);
        System.out.println(Arrays.toString(a));

    }
}

上述代码块演示了通过调用Arrays类的tostring方法对数组进行输出以及sort方法,具体的输出原理,可以自行查阅底层源码。

通过sort方法的调用,可以将数组中的元素进行升序排列,那么我们怎样将数组中的元素进行自定义排序呢?因为sort方法是重载的,可以通过传入一个接口comparator,实现定制排序。

调用定制的排序方法如下:

Arrays.sort(integers, new Comparator() {

            @Override
            public int compare(Object o1, Object o2) {
                return 0;
            }
        });

需要传入两个参数,一个是需要排序的数组,一个是实现了Comparator接口的匿名内部类。这个匿名内部类中实现了compare方法。

自定义排序方法(冒泡为内核):

public class ArraysSortCustom {
    public static void main(String[] args) {

        int[] arr = {1,-1,8,0,20};
        bubble02(arr, new Comparator() {
            @Override
            public int compare(Object o1, Object o2) {
                int i1 = (Integer)o1;
                int i2 = (Integer)o2;
                return i1 - i2;
            }
        });
        System.out.println(Arrays.toString(arr));
    }
    public static void bubble02(int[] arr, Comparator c) {
        int temp = 0;
        for (int i = 0; i < arr.length - 1; i++) {
            for (int j = 0; j < arr.length - 1 - i; j++) {
                if(c.compare(arr[j],arr[j+1])<0) {
                    temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
        }
    }
}

这种接口编程的思想,用到了匿名内部类,这种写法还是比较灵活的,需要多多体会。(sort方法的底层源码也是采用这种写法)。

array的自行实现是指在编程语言中,我们可以自己编写一个来实现数组的功能。在这个array中,我们可以使用一些常见的数组操作,比如添加元素、删除元素、查找元素等。 首先,我们需要定义一个数组的数据结构,可以是一个由元素组成的列表。我们可以使用一个内部数组来存储这些元素,并且定义一个变量来记录数组的长度。 接下来,我们可以实现一些常用的数组操作方法。例如,我们可以实现一个添加元素的方法,它接受一个参数作为要添加的元素,并将其添加到数组的末尾。我们还可以实现一个删除元素的方法,它接受一个参数作为要删除的元素,并将其从数组中删除。还可以实现一个查找元素的方法,它接受一个参数作为要查找的元素,并返回其在数组中的索引。 除了这些基本的操作方法之外,我们还可以实现一些其他的功能。例如,我们可以实现一个获取数组长度的方法,用于返回数组当前的长度。我们还可以实现一个遍历数组的方法,用于逐个输出数组中的所有元素。 当实现完这些基本的功能之后,我们可以对这个array进行测试,确保它能够正确地执行各种操作。我们可以创建一个数组实例,并调用其中的方法来测试其功能是否正常。如果遇到问题,我们可以检查代码并进行调试,直到问题得到解决为止。 总结起来,自行实现一个array需要定义数组的数据结构,并实现一些常用的数组操作方法。通过这个,我们可以方便地操作数组,并进行各种操作。这对于数据处理和算法设计都是十分有帮助的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值