Day04——数组

1.数组概述

定义

数组(Array),是多个相同类型数据一定顺序排列的集合,并使用一个名字命名,并通过编号的方式对这些数据进行统一管理。

常见概念

  • 数组名

  • 下标(或索引)

  • 元素

  • 数组的长度

数组的分类

  1. 按照维度分为:
  • 一维数组
  • 二维数组
  • 三维数组
  1. 按照元素的数据类型分为:
  • 基本数据类型元素的数组
  • 引用数据类型元素的数组(即对象数组)

注意事项

  • 数组本身是引用数据类型,而数组中的元素可以是任何数据类型,包括基本数据类型和引用数据类型。

  • 创建数组对象会在内存中开辟一整块连续的空间,而数组名中引用的是这块连续空间的首地址。

  • 数组的长度一旦确定,就不能修改

  • 我们可以直接通过下标(或索引)的方式调用指定位置的元素,速度很快。

2.一维数组的使用

声明方式

type var[];
type[] var;

例:

int a[];
int[] a1;
double b[];
String[] c; //引用类型变量数组

初始化

  1. 动态初始化:数组声明且为数组元素分配空间赋值的操作分开进行。

例:

int[] arr = new int[3]; 
arr[0] = 0;
arr[1] = 1;
arr[2] = 2;
  1. 静态初始化:在定义数组的同时就为数组元素分配空间并赋值。

例:

int arr[] = new int[]{0,1,2};
int[] arr = {0,1,2};

数组元素的引用

  1. 定义并用运算符new为之分配空间后,才可以引用数组中的每个元素。

  2. 数组元素的引用方式:数组名[数组元素下标]

  • 数组元素下标可以是整型常量整型表达式。如a[3] , b[i] , c[6*i]。

  • 数组元素下标从0开始;长度为n的数组合法下标取值范围: 0 —>n-1;如int a[]=new int[3]; 可引用的数组元素为a[0]、a[1]、a[2]。

  1. 每个数组都有一个属性length指明它的长度,例如:a.length指明数组a的长度(元素个数)。
  • 数组一旦初始化,其长度是不可变的。

数组元素的默认初始化值

  1. 数组是引用类型,它的元素相当于类的成员变量,因此数组一经分配空间,其中的每个元素也被按照成员变量同样的方式被隐式初始化。
  • 对于基本数据类型而言,默认初始化值各有不同。
  • 对于引用数据类型而言,默认初始化值为null(注意与0不同!)。
数组元素类型默认初始化值
byte0
short0
int0
long0L
float0.0F
double0.0
char0 或写为:’\u0000’(表现为空)
booleanfalse
引用数据类型null

3.一维数组的内存解析

Java将内存区域划分为5个部分:程序计数器、虚拟机栈、本地方法栈、堆、方法区。

int[] arr = new int[]{1,2,3};

与该数组相关的内存结构有堆(用于存放数组中的所有元素:1,2,3)、虚拟机栈(用于存放方法中声明的变量:arr)

4.多维数组的使用(二维数组)

初始化

  1. 动态初始化
  • 格式一:
int[][] arr = new int[3][2];

二维数组中有3个一维数组,每一个一维数组中有2个元素, 一维数组的名称分别为arr[0], arr[1], arr[2] 。赋值写法是:

arr[0][1] = 1;		//给第一个一维数组角标为1的元素赋值为1
  • 格式二:
	int[][] arr = new int[3][];

二维数组中有3个一维数组,每个一维数组都是默认初始化值null,可以对这个三个一维数组分别进行初始化,操作是:

arr[0] = new int[3]; 
arr[1] = new int[1]; 
arr[2] = new int[2];
  1. 静态初始化
int[][] arr = new int[][]{{3,8,2},{2,7},{9,0,1,6}};

二维数组中有三个一维数组,每一个一维数组中具体元素也都已初始化,第一个一维数组 arr[0] = {3,8,2};第二个一维数组 arr[1] = {2,7};第三个一维数组 arr[2] = {9,0,1,6}; 第三个一维数组的长度表示方式:arr[2].length。

5. 数组中的常见问题

赋值问题

例:(杨辉三角、回形数等)

package Day04;

/*
杨辉三角问题
*/

public class test4 {
    public static void main(String[] args) {
        int[][] yangHui = new int[10][];
        for (int i = 0; i < yangHui.length; i++) {
            yangHui[i] = new int[i + 1];
            yangHui[i][0] = 1;
            yangHui[i][i] = 1;
            for (int j = 1; j < yangHui[i].length - 1; j++) {
                yangHui[i][j] = yangHui[i - 1][j - 1] + yangHui[i - 1][j];
            }
        }

        for (int i = 0; i < yangHui.length; i++) {
            for (int j = 0; j < yangHui[i].length; j++) {
                System.out.print(yangHui[i][j] + " ");
            }
            System.out.println();
        }
    }
}

求值问题

例:求数值型数组中元素的最大值、最小值、平均数、总和等

package Day04;

/*
定义一个int型的一维数组,包含10个元素,分别赋一些随机整数,然后求出所有元素的最大值,最小值,和值,平均值,并输出出来。
要求:所有随机数都是两位数。
提示:[0,1) * 90 -> [0,90) + 10 -> [10,100) -> [10,99]
(int)(Math.random() * 90 + 10)
*/

public class test5 {
    public static void main(String[] args) {
        int[] arr = new int[10];

        //求和值和平均值
        int sum = 0;
        int average = 0;
        for (int i = 0; i < arr.length; i++) {
            //赋值
            arr[i] = (int) (Math.random() * 90 + 10);
            sum += arr[i];
            average = sum / arr.length;
        }
        //求最大值、最小值
        int max = arr[0];
        int min = arr[0];

        for (int i = 1; i < arr.length; i++) {
            if (arr[i] > max){
                max = arr[i];
            }
            if (arr[i] < min){
                min = arr[i];
            }
        }

        System.out.println("max = " + max);
        System.out.println("min = " + min);
        System.out.println("sum = " + sum);
        System.out.println("average = " + average);
    }
}

数组的复制、反转、查找

  1. 数组复制
				//数组复制
        arr2 = new int[arr1.length];
        for (int i = 0; i < arr2.length; i++) {
            arr2[i] = arr1[i];
        }
  1. 数组反转
				//数组反转
        for (int i = 0; i < arr1.length / 2; i++) {
             int temp = arr1[i];
             arr1[i] = arr1[arr1.length - i - 1];
             arr1[arr1.length - i - 1] = temp;
        } 
  1. 查找
  • 线性查找
				//线性查找,若查找到返回索引位置,若未找到则返回查找失败
        int a = 6;
		boolean isFlag = true;
        for (int i = 0; i < arr1.length; i++) {
            if (arr1[i] == a){
                System.out.println("查找成功,索引位置是:" + i);
              isFlag = false;
              break;
            }
        }
				if(isFlag){
          System.out.println("查找失败!");
        }
  • 二分查找(数组必须有序)
//二分查找,数组必须有序,若查找到返回索引位置,若未找到则返回查找失败
        int[] arr1 = new int[]{1,2,3,4,5,6,7,8};
        int a = 6;
        int head = 0;   //初始首索引
        int end = arr1.length - 1;      //初始尾索引
        boolean isFlag = true;
        while (head <= end){
            int middle = (head + end) / 2;
            if (a == arr1[middle]){
                System.out.p rintln("查找成功,索引位置是:" + middle);
                isFlag = false;
                break;
            }else if (a < arr1[middle]){
                end = middle - 1;
            }else {
                head = middle + 1;
            }
        }
        if (isFlag){
            System.out.println("查找失败!");
        }

数组的排序算法

  1. 直接选择排序

  2. 堆排序O(nlog^2n)

  3. 冒泡排序O(n^2)

public class 冒泡排序 {
    public static void main(String[] args) {
        int[] arr = new int[]{43,32,76,-98,0,64,33,-21,32,99};

        for (int i = 0; i < arr.length - 1; i++) {
            for (int j = 0; j < arr.length - 1 - i; j++) {
                if (arr[j] > arr[j + 1]){
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }

        }
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + "\t");
        }
    }
}
  1. 快速排序O(nlog^2n)
  2. 直接插入排序
  3. 折半插入排序
  4. Shell(希尔)排序
  5. 归并排序O(nlog^2n)
  6. 基数排序
  7. 桶式排序

6.Arrays工具类的使用

  • java.util.Arrays类即为操作数组的工具类,包含了用来操作数组(比如排序和搜索)的各种方法。

常用方法

方法作用
boolean equals(int[] a,int[] b)判断两个数组是否相等
String toString(int[] a)输出数组信息
void fill(int[] a,int val)用指定值替换数组中所有元素
void sort(int[] a)对数组进行排序
int binarySearch(int[] a,int key)对排序后的数组进行二分法检索指定的值
  • boolean equals(int[] a,int[] b)示例:
import java.util.Arrays;

public class ArraysTest {
    public static void main(String[] args) {
        int[] arr1 = new int[]{1,2,3,4,5};
        int[] arr2 = new int[]{1,2,3,4,5};
        boolean equals = Arrays.equals(arr1, arr2);
        System.out.println(equals);
    }
}
  • String toString(int[] a)示例:
import java.util.Arrays;

public class ArraysTest {
    public static void main(String[] args) {
        int[] arr1 = new int[]{1,2,3,4,5};
        String s = Arrays.toString(arr1);
        System.out.println(s);
    }
}
  • void fill(int[] a,int val)示例:
import java.util.Arrays;

public class ArraysTest {
    public static void main(String[] args) {
        int[] arr1 = new int[]{1,2,3,4,5};
        Arrays.fill(arr1, 6);
        System.out.println(Arrays.toString(arr1));
    }
}
  • void sort(int[] a)示例:
import java.util.Arrays;

public class ArraysTest {
    public static void main(String[] args) {
        int[] arr1 = new int[]{4,1,2,5,3};
        Arrays.sort(arr1);
        System.out.println(Arrays.toString(arr1));
    }
}
  • int binarySearch(int[] a,int key)示例:
import java.util.Arrays;

public class ArraysTest {
    public static void main(String[] args) {
      int[] arr1 = new int[]{1,2,3,4,5};
        int index = Arrays.binarySearch(arr1, 2);
        System.out.println(index);
    }
}

7.使用数组常见异常

数组脚标越界异常(ArrayIndexOutOfBoundsException)

原因:访问到了数组中的不存在的脚标时发生。

空指针异常(NullPointerException)

原因:arr引用没有指向实体,却操作实体中的元素。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值