数组(连续的存储空间): 使用数组的原因:
代码语言:javascript复制对相同类型的数据进行分类,便于管理,查找,避免大量变量的定义
数组在内存中的存储:
代码语言:javascript复制数组在内存中是一组连续的存储空间,而变量是独立的存储空间
数组的概念:
代码语言:javascript复制数组是一个特殊的变量,用于存储相同数据类型的一组数。
数组的定义:
代码语言:javascript复制1. 数据类型 数组名;
只声明数组,未进行分配空间和赋值。
2. 数据类型 数组名 = new 数据类型[大小];
声明数组并分配空间
3. 数据类型[] 数组名 = {数据1,数据2,数据3....数据n};
注意:
代码语言:javascript复制1.整数型数组中可以存放字符类型数据。
2.定义数组并分配空间,未进行赋值时,系统会给数组添加默认值(默认值和全局变量的默认值一致):
int类型默认值为0,double类型默认值为0.0,String类型默认值为null
数组长度:数组名.lenght; 数组的下标(索引):数组中的每个元素都有对应的下标,第一个元素对应的下标为0,以此类推。 获取数组指定下标的元素:
代码语言:javascript复制数组名[i]:i表示数组下标
遍历数组:
代码语言:javascript复制for (int i = 0 ; i < 数组名.lenght;i ){
System.out.println(数组名[数组下标]);
}
数组的常用算法: 数组的扩容: 由于数组无法动态改变大小,所以已经分配空间并赋值的数组中无法添加元素,故数组的扩容需要定义新的数组,步骤如下:
代码语言:javascript复制1.定义一个新数组,其大小为原数组大小 N;
2.复制原数组的元素到新数组。
求最值(擂台算法)
代码语言:javascript复制求最大值和最小值
1.定义一个新变量用于保存最大值或最小值。
2.循环依次将数组中的元素与定义的变量进行比较,将大的或小的元素赋值给定义的变量
3.最后输出定义的变量
数组中常用的工具类Arrays(通过import java.util.Arrays进行导入)
代码语言:javascript复制Arrays.toString(数组名); 打印数组元素
Arrays.store(数组名); 数组升序排序
反转数组思路:将数组从中间分割,交换数组前后数据 冒泡排序算法(重点)
代码语言:javascript复制循环对比将数组进行排序,可以升序排序,也可以降序排序。
int temp;
int[] array = {5,1,2,3,6,4,9};
for (int i = 0 ; i < array.lenght -1;i ){
for (int j = 0 ; j < array.lenght -1 -i; j ){
if(array[j] > array[j 1]){
temp = array[j];
array[j] = array[j 1];
array[j 1] = temp;
}
}
}
System.out.println(Arrays.toString(array));
插入排序 将数组排序,然后插入一个数组,使数组依然保持原有的排序规则
代码语言:javascript复制int[] array = new int[5];
array[0] = 1;
array[1] = 3;
array[2] = 5;
array[3] = 7;
Scanner sc = new Scanner(System.in);
System.out.println("请输入一个数");
int num = sc.nextInt();
int i;
for (int i = 0 ; i < array.lenght -1;i ){
if(array[i] > num){
break;
}
}
for (int j = array.lenght -1 ; j > 1;j ){
array[j] = array[j-1];
}
array[i] = num;
System.out.println(Arrays.toString(array));