数组
3.1 数组的概述
🌂 数组(Array),是多个相同类型数据按一定顺序排列
的集合,并使用一个名字命名,并通过编号的方式
对这些数据进行统一管理。
✔ 数组的常见概念
------🎈 数组名
------🎈下标(或索引)
------🎈元素
------🎈数组的长度
🌂数组本身是引用数据类型,而数组中的元素可以是任何数据类型,包括
基本数据类型和引用数据类型。
🌂创建数组对象会在内存中开辟一整块连续的空间,而数组名中引用的是
这块连续空间的首地址。
🌂数组的长度一旦确定,就不能修改。
🌂我们可以直接通过下标(或索引)的方式调用指定位置的元素,速度很快。
✔ 数组的分类:
------🎈按照维度:一维数组、二维数组、三维数组、…
------🎈按照元素的数据类型分:基本数据类型元素的数组、引用数据类型元素的数组(即对
象数组)
3.2 一维数组的使用
✔ 声明
🌂 一维数组的声明方式:
type var[] 或 type[] var;
例如:
int a[];
int[] a1;
double b[];
String[] c; //引用类型变量数组
🌂 Java语言中声明数组时不能指定其长度(数组中元素的数), 例如: int a[5]; //非法
✔ 初始化
💧 动态初始化:
数组声明且为数组元素分配空间与赋值的操作分开进行
💧 静态初始化:
在定义数组的同时就为数组元素分配空间并赋值。
✔ 数组元素的引用
🌂定义并用运算符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的长
度(元素个数)
------数组一旦初始化,其长度是不可变的
✔ 数组元素的默认初始化值
- 数组是引用类型,它的元素相当于类的成员变量,因此数组一经
分配空间,其中的每个元素也被按照成员变量同样的方式被隐式
初始化。例如:
public class Test {
public static void main(String argv[]){
int a[]= new int[5];
System.out.println(a[3]); //a[3]的默认值为0
}
}
对于基本数据类型而言,默认初始化值各有不同
对于引用数据类型而言,默认初始化值为null(注意与0不同!)
✔ 创建基本数据类型数组 (1)
✔ 创建基本数据类型数组 (2)
✔ 创建基本数据类型数组 (3)
✔ 内存的简化结构
✔ 一维数组的内存解析
✔ 一维数组的使用:例题
从键盘读入学生成绩,找出最高分,
并输出学生成绩等级。
成绩>=最高分-10 等级为’A’
成绩>=最高分-20 等级为’B’
成绩>=最高分-30 等级为’C’
其余
等级为’D’
提示:先读入学生人数,根据人数创建int数组,
存放学生成绩。
public class ArrayTest {
public static void main(String[] args) {
//1.使用Scanner,读取学生个数
System.out.println("请输入学生个数:");
Scanner scanner = new Scanner(System.in);
int number = scanner.nextInt();
//2.创建数组,存储学生成绩:动态初始化
int[] scores = new int[number];
//3.给数组中的元素赋值
System.out.println("请输入" + number + "个学生成绩:");
for(int i = 0; i < scores.length; i++) {
scores[i] = scanner.nextInt();
}
//4.获取数组中的元素的最大值:最高分
int maxScore = scores[0];
for(int i = 1; i < scores.length; i++) {
if(maxScore < scores[i]) {
maxScore = scores[i];
}
}
System.out.println("最高分是" + maxScore);
//5.根据每个学生成绩与最高分的插值,得到每个学生的等级,并输出等级和成绩
char level;
for(int i = 0; i < scores.length; i++) {
if(maxScore - scores[i] <= 10) {
level = 'A';
}else if(maxScore - scores[i] <= 20) {
level = 'B';
}else if(maxScore - scores[i] <= 30) {
level = 'C';
}else {
level = 'D';
}
System.out.println("student" + i
+ " score is " + scores[i] + ",grade is " + level);
}
}
}
输出结果:
请输入学生个数:
5
请输入5个学生成绩:
56
74
89
41
89
最高分是89
student0 score is 56,grade is D
student1 score is 74,grade is B
student2 score is 89,grade is A
student3 score is 41,grade is D
student4 score is 89,grade is A
3.3 多维数组的使用
二维数组[][]:数组中的数组
✔ (动态初始化)
格式1(动态初始化):int[][] arr = new int[3][2]; |
---|
定义了名称为arr的二维数组
二维数组中有3个一维数组
每一个一维数组中有2个元素
一维数组的名称分别为arr[0], arr[1], arr[2]
给第一个一维数组1脚标位赋值为78写法是:arr[0][1] = 78;
格式2(动态初始化):int[][] arr = new int[3][]; |
---|
二维数组中有3个一维数组。
每个一维数组都是默认初始化值null (注意:区别于格式1)
可以对这个三个一维数组分别进行初始化
arr[0] = new int[3]; arr[1] = new int[1]; arr[2] = new int[2];
注:
int[][]arr = new int[][3]; //非法
✔ (静态初始化)
格式3(静态初始化):int[][] arr = new int[][]{{3,8,2},{2,7},{9,0,1,6}}; |
---|
定义一个名称为arr的二维数组,二维数组中有三个一维数组
每一个一维数组中具体元素也都已初始化
第一个一维数组 arr[0] = {3,8,2};
第二个一维数组 arr[1] = {2,7};
第三个一维数组 arr[2] = {9,0,1,6};
第三个一维数组的长度表示方式:arr[2].length;
注意特殊写法情况:int[] x,y[]; x是一维数组,y是二维数组。
Java中多维数组不必都是规则矩阵形式
✔ 初始化使用
/**
* 二维数组的使用:
* 规定:二维数组分为外层数组的元素,内层数组的元素
* int[][] arr = new int[4][3];
* 外层元素:arr[0],arr[1]等
* 内层元素:arr[0][0],arr[1][2]等
*
*
*
*/
public class ArrayTest2 {
public static void main(String[] args) {
//1.二维数组的声明和初始化
int [] arr = new int[] {1,2,3}; //一维数组
//静态初始化
int[][] arr1 = new int[][]{{1,2,3},{4,5},{6,7,8}};
//动态初始化1
String[][] arr2 = new String[3][2];
//动态初始化2
String[][] arr3 = new String[3][];
//错误的情况
//String[][] arr4 = new String[][4];
//String[4][3] arr5 = new String[][];
//int[][] arr6 = new int[4][3]{{1,2,3},{4,5},{6,7,8}};
//也是正确的写法:
int[] arr4[] = new int[][] {{1,2,3},{4,5},{6,7,8}};
int[] arr5[] = {{1,2,3},{4,5},{6,7,8}};
//2.如何调用数组的指定位置元素
System.out.println(arr1[0][1]);//2
System.out.println(arr2[1][1]);//null
arr3[1] = new String[4];
System.out.println(arr3[1][0]);//null
//3.获取数组的长度
System.out.println(arr4.length);//3
System.out.println(arr4[0].length);//3
System.out.println(arr4[1].length);//2
//4.如何遍历二维数组
for(int i = 0; i < arr4.length; i++) {
for(int j = 0; j < arr4[i].length; j++) {
System.out.println(arr4[i][j]);
}
}
int[][] arr7 = new int[4][3];
System.out.println(arr7[0]);//[I@34c45dca 地址值
System.out.println(arr7[0][0]);//0
System.out.println(arr);//[I@52cc8049
System.out.println("*************");
String[][] arr2 = new String[4][2];
System.out.println(arr2[1]);//地址值
System.out.println(arr2[1][1]);//null
System.out.println("************");
String[][] arr8 = new String[4][];
System.out.println(arr3[1]);//null
}
}
✔ 二维数组的内存解析
💧 二维数组练习:杨辉三角
public class YangHuiTest {
public static void main(String[] args) {
//1.声明并初始化二维数组
int[][] yangHui = new int[10][];
//2.给数组的元素赋值
for(int i = 0; i < yangHui.length; i++) {
yangHui[i] = new int[i+1];
//2.1给首末元素赋值
yangHui[i][0] = 1;
yangHui[i][i] = 1;
//2.2给每行的非首末元素赋值
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();
}
}
}
💧 二维数组练习:
声明:int[] x,y[]; 在给x,y变量赋值以后,以下选项允许通过编译的是:
a ) x[0] = y; no
b) y[0] = x; yes
c) y[0][0] = x; no
d) x[0][0] = y; no
e) y[0][0] = x[0]; yes
f) x = y; no
提示:
一维数组:int[] x 或者int x[]
二维数组:int[][] y 或者 int[] y[] 或者 int y[][]
3.4 数组中涉及到的常见算法
- 数组元素的赋值(杨辉三角、回形数等)
- 求数值型数组中元素的最大值、最小值、平均数、总和等
- 数组的复制、反转、查找(线性查找、二分法查找)
- 数组元素的排序算法
3.5 Arrays工具类的使用
- java.util.Arrays类即为操作数组的工具类,包了用来操作数组(比如排序和搜索)的各种方法。
1 | boolean equals(int[] a,int[] b) | 判断两个数组是否相等。 |
2 | String toString(int[] a) | 输出数组信息。 |
3 | void fill(int[] a,int val) | 将指定值填充到数组之中。 |
4 | void sort(int[] a) | 对数组进行排序。 |
5 | int binarySearch(int[] a,int key) | 对排序后的数组进行二分法检索指定的值。 |
数组排序
import java.util.Arrays;
public class SortTest {
public static void main(String[] args) {
int [] numbers = {5,900,1,5,77,30,64,700};
Arrays.sort(numbers);
for(int i = 0; i < numbers.length; i++){
System.out.println(numbers[i]);
}
}
}
3.6 数组使用中的常见异常
✔ 数组脚标越界异常(ArrayIndexOutOfBoundsException)
int[] arr = new int[2];
System.out.println(arr[2]);
System.out.println(arr[-1]);
访问到了数组中的不存在的脚标时发生。
✔ 空指针异常(NullPointerException)
int[] arr = null;
System.out.println(arr[0]);
arr引用没有指向实体,却在操作实体中的元素时。