1. 数组定义
- 数组是相同类型数据的有序集合
- 数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成
- 其中,每个数据称作一个数组元素,每个数组元素可以通过一个下标来访问它们
2. 数组声明和创建
-
首先必须声明数组变量,才能在程序中使用数组。
dataType[] arrayRefVar;//首选的方法 或![在这里插入图片描述](https://img-blog.csdnimg.cn/7e51513c6a374fa3b6cbab7d68f6d3f4.png) dataType arrayRefVar[];//效果相同,但不是首选方法,c/c++用的形式
-
Java中使用new操作符来创建数组
dataType[] arrayRefVar = new dataType[arraySize];
-
数组的元素是通过索引访问的,数组索引从0开始
-
获取数组长度:
arrays.length()
int类型默认值为0,string类型默认值为null
public static void main(String[] args) { int[] array01;//1. 声明数组 array01 = new int[10];//2. 创建一个数组 //可以存放10个int类型的数字 int[] array02 = new int[5];//声明和创建合成一句 int value = 1;//3. 给数组中元素赋值 int sum = 0; for (int i = 0; i < array01.length; i++) { array01[i] = value++; sum += array01[i]; System.out.print(array01[i]+"\t"); } System.out.println(); System.out.println("总和为:" + sum); }
//输出 1 2 3 4 5 6 7 8 9 10 总和为:55
-
数组的4个基本特点
- 其长度是确定的。一旦被创建,大小不可以改变。
- 其元素必须是相同类型的,不允许出现混合类型。
- 数组中的元素可以是任何类型,包括基本类型、引用类型。
- 数组变量属于引用变量,数组也可以看成是对象,数组中的每个元素相当于该对象的成员变量。Java中的对象是在堆中的,因此数组无论保存原始类型还是其他对象类型,数组对象本身是在堆中的。
3. Java内存分析
- new事件都在堆里面
- 初始声明一个数组在栈中,分配内存在堆中,如果数组长度为10,则十个数组元素在同一块内存中,如有超过下标的,不在内存中。
- 常见的报错:【数组下标越界】java.lang.ArrayIndexOutOfBoundsException
4. 三种初始化:
- 静态初始化:
- 动态初始化:
- 数组的默认初始化:
- 数组是引用类型,它的元素相当于类的实例变量。数组一经分配空间,其中的每个元素也被按照实例变量同样的方式被隐式初始化。
public static void main(String[] args) {
//静态初始化:创建+赋值
int[] a = {1,2,3,4,5,6};
System.out.println(a[0]);
//动态初始化:包含默认初始化
int[] ints = new int[10];
ints[0] = 3;
System.out.println(ints[0]);
System.out.println(ints[1]);//默认初始化值为0
System.out.println(ints[2]);//默认初始化值为0
System.out.println(ints[3]);//默认初始化值为0
System.out.println(ints[4]);//默认初始化值为0
}
小结:
- 数组是相同数据类型(数据类型可以为任意类型)的有序集合
- 数组也是对象(因为是new出来的)。数组元素相当于对象的成员变量。
- 数组的长度是确定的,不可变的。如果越界就会报错。
5. 数组使用
-
基础使用
- 普通的for循环
public static void main(String[] args) { //1. 打印所有元素 int[] array = {6,7,8,9,10,1,2,3,4,5}; for (int i = 0; i < array.length; i++) { System.out.println("array["+i+"]:"+array[i]); } //2. 计算所有元素的和 int sum = 0; for (int i = 0; i < array.length; i++) { sum += array[i]; } System.out.println("array的元素和为:"+sum); //3. 查找最大元素 int max = array[0]; for (int i = 1; i < array.length; i++) { //下标从1开始减少一次循环 if (array[i]>max){ max = array[i]; } } System.out.println("array中最大的元素为:" + max); }
//输出 array[0]:6 array[1]:7 array[2]:8 array[3]:9 array[4]:10 array[5]:1 array[6]:2 array[7]:3 array[8]:4 array[9]:5 array的元素和为:55 array中最大的元素为:10
-
进阶使用
- foreach循环(省去了数组下标)
- 数组作方法入参
- 数组作返回值
public static void main(String[] args) { int[] arrays = {1,2,3,4,5,6}; //jdk 1.5以上版本开始有的,省去了数组下标 // for (int array : arrays) { // System.out.println(array); // } // //数组作为方法的参数 // printArray(arrays); int[] reverse = reverse(arrays); printArray(arrays);//打印反转后的 printArray(reverse);//打印反转后的 } //打印数组元素 public static void printArray(int[] array){ for (int i = 0; i < array.length; i++) { System.out.print(array[i]+" "); } System.out.println(); } //反转数组 public static int[] reverse(int[] array){ int[] ints = new int[array.length]; for (int i = 0, j = array.length-1; i < array.length; i++,j--) { ints[j] = array[i]; } return ints; }
//输出 1 2 3 4 5 6 6 5 4 3 2 1
6. 多维数组
可以看成是数组的数组,比如二维数组就是一个特殊的一维数组,其中每个元素都是一个一维数组。
int a[][] = new int[2][5]
以上二维数组a可以看成一个两行五列的数组。
二维数组:
public static void main(String[] args) {
//即:4行2列数组
/*
1 2 doubleArray[0]
2 3 doubleArray[1]
3 4 doubleArray[2]
4 5 doubleArray[3]
*/
int[][] doubleArray = {{1,2},{2,3},{3,4},{4,5}};
//直接打印doubleArray[0],打印的是地址,可以借助取值方法来输出。
System.out.println(doubleArray[0]);
printArray(doubleArray[0]);
System.out.println(doubleArray[0][0]);
System.out.println(doubleArray[0][1]);
//打印长度
System.out.println(doubleArray.length);
System.out.println(doubleArray[0].length);
//打印每一个元素
for (int i = 0; i < doubleArray.length; i++) {
for (int j = 0; j < doubleArray[i].length; j++) {
System.out.print(doubleArray[i][j] + " ");
}
}
}
//打印数组元素
public static void printArray(int[] array){
for (int i = 0; i < array.length; i++) {
System.out.print(array[i]+" ");
}
System.out.println();
}
[I@1540e19d
1 2
1
2
4
2
1 2 2 3 3 4 4 5
三维数组:
public static void main(String[] args) {
int[][][] a = {{{1,2,3},{4,5,6}},{{7,8,9},{10,11,12}}};
printArray(a);
}
//打印方法
public static void printArray(int[][][] array){
for (int i = 0; i < array.length; i++) {
for (int j = 0; j < array[i].length; j++) {
for (int k = 0; k < array[i][j].length; k++) {
System.out.print(array[i][j][k]+" ");
}
}
}
}
//输出
1 2 3 4 5 6 7 8 9 10 11 12
7. Arrays类
-
Arrays.toString()
:打印数组元素public static void main(String[] args) { int[] a = {1,2,3,4,5,6}; System.out.println(Arrays.toString(a));//打印数组元素 //这种工具类也可以自己写,但是不建议重复造轮子,可以了解原理 printArray(a); } //自己写打印方法 public static void printArray(int[] array){ System.out.print("["); for (int i = 0; i < array.length; i++) { if (i == array.length-1){ System.out.print(array[i]); }else { System.out.print(array[i]+", "); } } System.out.print("]"); }
//输出 [1, 2, 3, 4, 5, 6] [1, 2, 3, 4, 5, 6]
-
Arrays.sort()
:对数组进行排序(升序)int[] a = {4,5,6,1,2,3}; Arrays.sort(a); System.out.println(Arrays.toString(a));
[1, 2, 3, 4, 5, 6]
-
Arrays.fill()
:数组填充public static void main(String[] args) { int[] a = {4,5,6,1,2,3}; //数组填充 Arrays.fill(a, 0);//所有元素填充0 System.out.println(Arrays.toString(a)); }
[0, 0, 0, 0, 0, 0]
public static void main(String[] args) { int[] a = {4,5,6,1,2,3}; //数组填充 Arrays.fill(a, 2,3,0);//2≤x<3之间元素填充0 System.out.println(Arrays.toString(a)); }
[1, 2, 0, 4, 5, 6]
8. 冒泡排序
最出名的排序算法之一(总共有八大排序)
思想:
- 比较数组中,两个相邻的元素,如果第一个数比第二个数大,就交换他们的位置
- 每一次比较,都会产生出一个最大或者最小的数(则之后的循环比较就可以比上一次少1)
- 下一轮则可以少一次排序
- 依次循环,直到结束
//优化:通过flag标识位减少没有意义的比较,已经有序的情况下不需要再进行比较
public static void main(String[] args) {
int[] a = {1,5,3,7,8,2};
bubbleSort(a);
System.out.println(Arrays.toString(a));
}
public static void bubbleSort(int[] array){
//升序为例
//外层循环:n个数需要n-1次
int temp ;
int count = 0;//排序进行的次数
for (int i = 0; i < array.length-1; i++) {
//内存循环:当前数值与后一位数值作比较
boolean flag = false;
for (int j = 0; j < array.length-1-i; j++) {
if (array[j] > array[j+1]){
temp = array[j];
array[j] = array[j+1];
array[j+1] = temp;
flag = true;
}
}
count++;
if (flag == false){
break;
}
}
System.out.println(count);
}
9. 稀疏数组
数组中大部分元素为0,或者为同一值的数组,可以使用稀疏数组来保存
-
首先记录数组有几行几列,有多少个不同的值
-
把具有不同值的元素、行列、值记录在一个小规模的数组中,从而缩小程序的规模。
public static void main(String[] args) {
//1. 创建一个二维数组 11*11 ,0:表示没有棋子,1:表示黑棋,2:表示白棋
int[][] ints = new int[11][11];
ints[1][2] = 1;
ints[2][3] = 2;
//原始二维数组
for (int i = 0; i < ints.length; i++) {
for (int j = 0; j < ints[i].length; j++) {
System.out.print(ints[i][j]+"\t");
}
System.out.println();
}
System.out.println("----------------------------");
//转换为稀疏数组保存
//1.获取有效值的个数
int count = 0;
for (int i = 0; i < 11; i++) {
for (int j = 0; j < 11; j++) {
if (ints[i][j] != 0){
count++;
}
}
}
System.out.println("有效值的个数为:" + count);
//2.创建一个稀疏数组
int[][] sparseArray = new int[count+1][3];
sparseArray[0][0] = ints.length;
sparseArray[0][1] = ints[0].length;
sparseArray[0][2] = count;
//3.遍历二维数组,将非零元素存入稀疏数组中
int num = 0;
for (int i = 0; i < ints.length; i++) {
for (int j = 0; j < ints[i].length; j++) {
if (ints[i][j] != 0){
num++;
sparseArray[num][0] = i;
sparseArray[num][1] = j;
sparseArray[num][2] = ints[i][j];
}
}
}
//4.输出稀疏数组
for (int i = 0; i < sparseArray.length; i++) {
for (int j = 0; j < sparseArray[i].length; j++) {
System.out.print(sparseArray[i][j]+"\t");
}
System.out.println();
}
System.out.println("---------------------------");
//5.还原稀疏数组
int[][] reArray = new int[sparseArray[0][0]][sparseArray[0][1]];
for (int i = 1; i < sparseArray.length; i++) {
reArray[sparseArray[i][0]][sparseArray[i][1]] = sparseArray[i][2];
}
//6.打印还原的数组
for (int i = 0; i < reArray.length; i++) {
for (int j = 0; j < reArray[i].length; j++) {
System.out.print(reArray[i][j] + "\t");
}
System.out.println();
}
}
//结果
0 0 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0 0
0 0 0 2 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
----------------------------
有效值的个数为:2
11 11 2
1 2 1
2 3 2
-----------------------------
0 0 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0 0
0 0 0 2 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0