欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java自学-数组 Arrays

程序员文章站 2022-07-21 19:23:07
java.util.Arrays类常用方法 Arrays 是针对数组的工具类,可以进行 排序,查找,复制填充等功能。 大大提高了开发人员的工作效率。 步骤 1 : 数组复制 与使用System.arraycopy进行数组复制类似的, Arrays提供了一个 copyOfRange 方法进行数组复制。 ......

java.util.arrays类常用方法

arrays是针对数组的工具类,可以进行 排序,查找,复制填充等功能。 大大提高了开发人员的工作效率。

步骤 1 : 数组复制

与使用system.arraycopy进行数组复制类似的, arrays提供了一个copyofrange方法进行数组复制。
不同的是system.arraycopy,需要事先准备好目标数组,并分配长度。 copyofrange 只需要源数组就就可以了,通过返回值,就能够得到目标数组了。
除此之外,需要注意的是 copyofrange 的第3个参数,表示源数组的结束位置,是取不到的

import java.util.arrays;
 
public class helloworld {
    public static void main(string[] args) {
        int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
 
        // copyofrange(int[] original, int from, int to)
        // 第一个参数表示源数组
        // 第二个参数表示开始位置(取得到)
        // 第三个参数表示结束位置(取不到)
        int[] b = arrays.copyofrange(a, 0, 3);
 
        for (int i = 0; i < b.length; i++) {
            system.out.print(b[i] + " ");
        }
 
    }
}

步骤 2 : 转换为字符串

如果要打印一个数组的内容,就需要通过for循环来挨个遍历,逐一打印

但是arrays提供了一个tostring()方法,直接把一个数组,转换为字符串,这样方便观察数组的内容

import java.util.arrays;
  
public class helloworld {
    public static void main(string[] args) {
        int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
        string content = arrays.tostring(a);
        system.out.println(content);
  
    }
}

步骤 3 : 排序

在前面学习了 选择法排序 和 冒泡法排序,arrays工具类提供了一个sort方法,只需要一行代码即可完成排序功能。

Java自学-数组 Arrays

import java.util.arrays;
  
public class helloworld {
    public static void main(string[] args) {
        int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
        system.out.println("排序之前 :");
        system.out.println(arrays.tostring(a));
        arrays.sort(a);
        system.out.println("排序之后:");
        system.out.println(arrays.tostring(a));
  
    }
}

步骤 4 : 搜索

查询元素出现的位置
需要注意的是,使用binarysearch进行查找之前,必须使用sort进行排序
如果数组中有多个相同的元素,查找结果是不确定的

Java自学-数组 Arrays

 import java.util.arrays;
     
    public class helloworld {
        public static void main(string[] args) {
            int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
     
            arrays.sort(a);
     
            system.out.println(arrays.tostring(a));
            //使用binarysearch之前,必须先使用sort进行排序
            system.out.println("数字 62出现的位置:"+arrays.binarysearch(a, 62));
        }
    }

步骤 5 : 判断是否相同

比较两个数组的内容是否一样
第二个数组的最后一个元素是8,和第一个数组不一样,所以比较结果是false

import java.util.arrays;
 
public class helloworld {
    public static void main(string[] args) {
        int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
        int b[] = new int[] { 18, 62, 68, 82, 65, 8 };
 
        system.out.println(arrays.equals(a, b));
    }
}

步骤 6 : 填充

使用同一个值,填充整个数组

Java自学-数组 Arrays

import java.util.arrays;
  
public class helloworld {
    public static void main(string[] args) {
        int a[] = new int[10];
  
        arrays.fill(a, 5);
  
        system.out.println(arrays.tostring(a));
  
    }
}

练习

(首先定义一个5x8的二维数组,然后使用随机数填充满。
借助arrays的方法对二维数组进行排序。
参考思路:
先把二维数组使用system.arraycopy进行数组复制到一个一维数组
然后使用sort进行排序
最后再复制回到二维数组。)