• java的Arrays工具类实战


     java.util.Arrays类能方便地操作数组,它提供的所有方法都是静态的。静态方法是属于类的,不是属于类的对象。所以可以直接使用类名加方法名进行调用。Arrays作为一个工具类,能很好的操作数组。下面介绍主要使用的几个函数。

      1.fill方法

      fill方法主要用来填充数组,这里我们举最简单的int类型吧(其它类型的一样)

      看Arrays的fill源码

      

      示例代码:

      Java代码

    1. publicstaticvoidmain(String[] args) {

    2. inta[]=newint[5];

    3. //fill填充数组

    4. Arrays.fill(a,1);

    5. for(inti=0;i<5;i++)//输出5个1

    6. System.out.println(a[i]);

    7. }

      填充部分数组源码:

      

      示例:

      Java代码

    1. publicstaticvoidmain(String[] args) {

    2. inta[]=newint[5];

    3. //fill填充数组

    4. Arrays.fill(a,1,2,1);

    5. for(inti=0;i<5;i++)//a[1]=1,其余默认为0

    6. System.out.println(a[i]);

    7. }

      2.sort方法

      从方法名看都知道是给数组排序,依然用int类型来说,其它类型一样的。

      一样有整个数组排序,如

      Java代码

    1. publicstaticvoidmain(String[] args) {

    2. inta[]={2,4,1,3,7};

    3. Arrays.sort(a);

    4. for(inti=0;i<5;i++)//升序

    5. System.out.println(a[i]);

    6. }

      指定数组部分排序:

      Java代码

    1. publicstaticvoidmain(String[] args) {

    2. inta[]={2,4,1,3,7};

    3. Arrays.sort(a,1,4); //输出2,1,3,4,7

    4. for(inti=0;i<5;i++)

    5. System.out.println(a[i]);

    6. }

      3.equals方法

      用于比较两个数组中的元素值是否相等,还是看int类型的数组。看Arrays源码

      

      示例:

      Java代码

    1. publicstaticvoidmain(String[] args) {

    2. inta[]={2,4,1,3,7};

    3. inta1[]={2,4,1,5,7};

    4. System.out.println(Arrays.equals(a1, a)); //输出false

    5. }

      4.binarySearch方法

      通过binarySearch方法能对排序好的数组进行二分查找法操作。看源码如下

      

      示例:

      Java代码

    1. publicstaticvoidmain(String[] args) {

    2. inta[]={2,4,1,3,7};

    3. Arrays.sort(a);//先排序

    4. System.out.println(Arrays.binarySearch(a, 4));//二分查找,输出3

    5. }

      5.copyof方法

      复制数组,Arrays的copyOf()方法传回的数组是新的数组对象,所以您改变传回数组中的元素值,也不会影响原来的数组

      如:

      Java代码

    1. importjava.util.Arrays;

    2. publicclassArrayDemo {

    3. publicstaticvoidmain(String[] args) {

    4. int[] arr1 = {1, 2, 3, 4, 5};

    5. int[] arr2 = Arrays.copyOf(arr1, arr1.length);

    6. for(inti = 0; i < arr2.length; i++)

    7. System.out.print(arr2[i] + " ");

    8. System.out.println();

    9. }

    10. }

  • 相关阅读:
    信息学奥赛一本通(C++)在线评测系统——基础(一)C++语言—— 1044:判断是否为两位数
    1043:整数大小比较
    1043:整数大小比较
    1043:整数大小比较
    排序算法 —— 插入排序
    排序算法 —— 插入排序
    排序算法 —— 插入排序
    C#中如何获取一个字体的宽度值(像素单位)
    visual studio 恢复默认界面
    visual studio 恢复默认界面
  • 原文地址:https://www.cnblogs.com/kaige123/p/5742905.html
Copyright © 2020-2023  润新知