246、Java基础23 - 数组【Arrays】 2019.11.14

62 篇文章 0 订阅
6 篇文章 0 订阅

1、Arrays

  • Arrays是针对数组的工具类,可以进行 排序,查找,复制填充等功能。 大大提高了开发人员的工作效率。
    在这里插入图片描述

2、copyOfRange() 数组复制

  • 与使用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] + " "); // 输出打印数组b[i]
        }
 
    }
}

3、toString() 转换为字符串

  • 如果要打印一个数组的内容,就需要通过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);
  
    }
}

4、sort() 排序

  • 在前面章节学习了 选择法排序 和 冒泡法排序, Arrays工具类提供了一个sort方法,只需要一行代码即可完成排序功能。
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));
  
    }
}

5、binarySerach() 搜索

  • 查询元素出现的位置
  • 需要注意的是,使用binarySearch进行查找之前,必须使用sort进行排序
  • 如果数组中有多个相同的元素,查找结果是不确定的
    在这里插入图片描述
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));
    }
}

6、equals() 判断是否相同

  • 比较两个数组的内容是否一样
  • 第二个数组的最后一个元素是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));
    }
}

7、fill() 填充

使用同一个值,填充整个数组
在这里插入图片描述

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));
  
    }
}

8、练习:二维数组排序

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

关于随机数
0-100的 随机整数的获取办法有多种,下面是参考办法之一:

(int) (Math.random() * 100)

Math.random() 会得到一个0-1之间的随机浮点数,然后乘以100,并强转为整型即可。

import java.util.Arrays;
  
public class HelloWorld {
public static void main(String[] args) {
    
int[][] dArray = new int[5][8]; // 定义二维数组
        System.out.println("----二维数组---");
        for (int i = 0; i < dArray.length ; i++) //填充数据
        {
            for (int j = 0; j < dArray[i].length; j++)
            {
                dArray[i][j] = (int)(Math.random() * 100);
            }
            System.out.println(Arrays.toString(dArray[i]));
        }
 
        int[] array = new int[dArray.length * dArray[0].length]; // 声明一维数组长度
        for (int i = 0; i < dArray.length; i++) // 将二维数组的内容全部复制到一维数组
        {
            System.arraycopy(dArray[i],0,array,i*dArray[0].length,dArray[0].length);
        }
        Arrays.sort(array); // 一维数组排序
        System.out.println("二维数组:排序后----");
        for (int i = 0; i <dArray.length ; i++) { // 复制到二维数组中的每个一维数组
            dArray[i] = Arrays.copyOfRange(array,i * dArray[0].length,dArray.length * (1+i));
            System.out.println(Arrays.toString(dArray[i]));
            
      }
}

9、参考链接

[01] How2j - 数组系列教材 (七)- JAVA.UTIL.ARRAYS类常用方法

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值