1.数组概述
定义
数组(Array),是多个相同类型数据按一定顺序排列的集合,并使用一个名字命名,并通过编号的方式对这些数据进行统一管理。
常见概念
-
数组名
-
下标(或索引)
-
元素
-
数组的长度
数组的分类
- 按照维度分为:
- 一维数组
- 二维数组
- 三维数组
- 按照元素的数据类型分为:
- 基本数据类型元素的数组
- 引用数据类型元素的数组(即对象数组)
注意事项
-
数组本身是引用数据类型,而数组中的元素可以是任何数据类型,包括基本数据类型和引用数据类型。
-
创建数组对象会在内存中开辟一整块连续的空间,而数组名中引用的是这块连续空间的首地址。
-
数组的长度一旦确定,就不能修改。
-
我们可以直接通过下标(或索引)的方式调用指定位置的元素,速度很快。
2.一维数组的使用
声明方式
type var[];
type[] var;
例:
int a[];
int[] a1;
double b[];
String[] c; //引用类型变量数组
初始化
- 动态初始化:数组声明且为数组元素分配空间与赋值的操作分开进行。
例:
int[] arr = new int[3];
arr[0] = 0;
arr[1] = 1;
arr[2] = 2;
- 静态初始化:在定义数组的同时就为数组元素分配空间并赋值。
例:
int arr[] = new int[]{0,1,2};
int[] arr = {0,1,2};
数组元素的引用
-
定义并用运算符new为之分配空间后,才可以引用数组中的每个元素。
-
数组元素的引用方式:数组名[数组元素下标]。
-
数组元素下标可以是整型常量或整型表达式。如a[3] , b[i] , c[6*i]。
-
数组元素下标从0开始;长度为n的数组合法下标取值范围: 0 —>n-1;如int a[]=new int[3]; 可引用的数组元素为a[0]、a[1]、a[2]。
- 每个数组都有一个属性length指明它的长度,例如:a.length指明数组a的长度(元素个数)。
- 数组一旦初始化,其长度是不可变的。
数组元素的默认初始化值
- 数组是引用类型,它的元素相当于类的成员变量,因此数组一经分配空间,其中的每个元素也被按照成员变量同样的方式被隐式初始化。
- 对于基本数据类型而言,默认初始化值各有不同。
- 对于引用数据类型而言,默认初始化值为null(注意与0不同!)。
数组元素类型 | 默认初始化值 |
---|---|
byte | 0 |
short | 0 |
int | 0 |
long | 0L |
float | 0.0F |
double | 0.0 |
char | 0 或写为:’\u0000’(表现为空) |
boolean | false |
引用数据类型 | null |
3.一维数组的内存解析
Java将内存区域划分为5个部分:程序计数器、虚拟机栈、本地方法栈、堆、方法区。
int[] arr = new int[]{1,2,3};
与该数组相关的内存结构有堆(用于存放数组中的所有元素:1,2,3)、虚拟机栈(用于存放方法中声明的变量:arr)
4.多维数组的使用(二维数组)
初始化
- 动态初始化
- 格式一:
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];
- 静态初始化
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);
}
}
数组的复制、反转、查找
- 数组复制
//数组复制
arr2 = new int[arr1.length];
for (int i = 0; i < arr2.length; i++) {
arr2[i] = arr1[i];
}
- 数组反转
//数组反转
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;
}
- 查找
- 线性查找
//线性查找,若查找到返回索引位置,若未找到则返回查找失败
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("查找失败!");
}
数组的排序算法
-
直接选择排序
-
堆排序O(nlog^2n)
-
冒泡排序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");
}
}
}
- 快速排序O(nlog^2n)
- 直接插入排序
- 折半插入排序
- Shell(希尔)排序
- 归并排序O(nlog^2n)
- 基数排序
- 桶式排序
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引用没有指向实体,却操作实体中的元素。