【Java】(十)数组、Arrays类、稀疏矩阵

文章目录

数组声明创建

数组存储同一类型的数据元素,需要:

  1. 先声明(指明类型)int[] nums;(推荐)或者int nums[];(方便c/c++)
  2. 定义(指明数组大小)nums = new int[10]; //动态初始化
  3. 调用(赋值)nums[0]=0;
    数组是引用类型,它的元素相当于类的实例变量,因此数组一经分配空间,其中的每个元素也被按照实例变量同样的方式被隐式初始化。

以上三个步骤可以分开也可以合并为一个语句int[] a = {1,2,3}; //静态初始化

已定义好的数组不能再改变大小。
数组中的元素可以是任何数据类型,包括基本类型和引用类型。Man[] mans = {new Man( 1,1) ,new Man(2,2)};

多维数组的初始化

动态初始化:int a[][] = new int[2][5];
静态初始化:int[][] array = {{1,2},{2,3},{3,4},{4,5}};

Java内存

数组变量属引用类型,数组也可以看成是对象,数组中的每个元素相当于该对象的成员变量。数组本身就是对象,Java中对象是在堆中的,因此数组无论保存原始类型还是其他对象类型,数组对象本身是在堆中的。
【Java】(十)数组、Arrays类、稀疏矩阵
【Java】(十)数组、Arrays类、稀疏矩阵

Arrays类

数组的工具类java.util.Arrays。由于数组对象本身并没有什么方法可以供我们调用,但API中提供了一个工具类Arrays供我们使用,从而可以对数据对象进行一些基本的操作。

可以查看JDK帮助文档搜索方法并调用。【搜索下载JDK 1.8 API或在线看】

Arrays类中的方法都是static修饰的静态方法,在使用的时候可以直接使用类名进行调用,而不用使用对象来调用。
具有以下常用功能:

  1. 给数组赋值:通过fil方法。Arrays.fill(数组名,开始序号,结束序号,默认填充值);
  2. 对数组排序:通过sort方法,按升序。Arrays.sort(数组名);
  3. 比较数组:通过equals 方法比较数组中元素值是否相等。boolean k = Arrays.equals(arr1,arr2);
  4. 查找数组元素:通过binarySearch方法能对排序好的数组进行二分查找法操作。int num = Arrays.binarySearch(Arr, 15);
package base;

import java.util.Arrays;

public class Array {
    public static void main(String[] args) {
        int[] Arr = {12,34,23,5,78,15,23,9};
        System.out.println("原数组:"+Arrays.toString(Arr)); //打印数组方法

        Arrays.sort(Arr); //数组排序方法
        System.out.println("排序后数组:"+Arrays.toString(Arr));

        int num = Arrays.binarySearch(Arr, 15); //对排序好的数组进行值查找(二分)
        System.out.println("数字15在数组中的索引位置为:"+num);

        int[] Arr2 = new int[5];//新建一个大小为5的数组
        Arrays.fill(Arr2, 2,4,6);//给第2位(0开始)到第4位(不包括)赋值6
        String str = Arrays.toString(Arr2); // Arrays类的toString()方法能将数组中的内容全部打印出来
        System.out.println("使用fill方法创建数组:"+str);

        int[] arr1 = {1,2,3};
        int[] arr2 = {1,2,3};
        boolean k = Arrays.equals(arr1,arr2);
        System.out.println("比较数组是否相等:"+k);
    }

}

稀疏矩阵

【Java】(十)数组、Arrays类、稀疏矩阵

上一篇:Java数组


下一篇:数组