java数组Array类(数组的方法类)

36 篇文章 3 订阅

简介 关键字

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

在这里插入图片描述

步骤 1 : 数组复制

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

package lesson7;

import java.util.Arrays;

public class test {
    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 test{
    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方法,只需要一行代码即可完成排序功能。

import java.util.Arrays;
 
public class test {
    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进行排序

如果数组中有多个相同的元素,查找结果是不确定的

import java.util.Arrays;

public class test{
	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 test{
    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 : 填充

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

import java.util.Arrays;
  
public class test{
    public static void main(String[] args) {
        int a[] = new int[10];
  
        Arrays.fill(a, 5);
  
        System.out.println(Arrays.toString(a));
  
    }
}

在这里插入图片描述

步骤 7 : 练习-二维数组排序

首先定义一个5X8的二维数组,然后使用随机数填充满。
借助Arrays的方法对二维数组进行排序。

参考思路:
先把二维数组使用System.arraycopy进行数组复制到一个一维数组
然后使用sort进行排序
最后再复制回到二维数组。

关于随机数
0-100的 随机整数的获取办法有多种,下面是参考办法之一:
(int) (Math.random() * 100)
Math.random() 会得到一个0-1之间的随机浮点数,然后乘以100,并强转为整型即可。

增强型for循环:https://blog.csdn.net/qq_35629971/article/details/119234053
增强型for循环:

java复制数组System.arraycopy

package lesson7;

import java.util.Arrays;
import java.util.Random;

public class test1 {
    public static void main(String[] args) {
        int[][] a=new int[5][8];
        int[]b=new int[40];
        Random random=new Random();
        for (int i = 0; i <a.length ; i++) {
            for (int j = 0; j <a[i].length ; j++) {
                a[i][j]=random.nextInt(100);//0-100
            }
              /*先把二维数组使用System.arraycopy进行数组复制到一个一维数组
                然后使用sort进行排序 最后再复制回到二维数组。*/
            System.arraycopy(a[i],0,b,a[i].length*i,a[i].length);
        }

        System.out.println("原来的数组:");
        for (int i = 0; i < a.length; i++) {
            // 这一整段都是用来验证是否正确的
            for (int j = 0; j < a[i].length; j++) {
                System.out.print(a[i][j]+"\t");
            }
            System.out.println();
        }

        //排序
        Arrays.sort(b);
        //复制回到二维数组
        for (int i = 0; i <a.length ; i++) {
            System.arraycopy(b,a[i].length*i,a[i],0,a[i].length);
        }

//        for (int[]i:a) {
//            for (int j:i) {
//                System.out.print(j+" ");
//            }
//            System.out.println();
//        }
//
//        //空一行方便打印效果
//        System.out.println("\n");

        System.out.println("排序后的数组:");
        for (int i = 0; i < a.length; i++) {
            // 这一整段都是用来验证是否正确的
            for (int j = 0; j < a[i].length; j++) {
                System.out.print(a[i][j]+"\t");
            }
            System.out.println();
        }

    }
}

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值