数组
概念
容器:是将多个数据存储到一起,每个数据称为该容器的元素。
数组:是存储数据长度固定的容器,保证多个数据的数据类型要一致。
定义
1)定义一(动态初始化:指定长度)
数组存储的数据类型[] 数组名字 = new 数组存储的数据类型[长度];
2)定义二(静态初始化:指定内容)
数据类型[] 数组名 = new 数据类型[]{元素1,元素2,元素3…}
3)定义三(省略静态初始化)
数据类型[] 数组名 = {元素1,元素2,元素3…}
访问
索引:每一个存储到数组的元素,都会自动的拥有一个编号,从0开始,这个自动编号称为数组索引 (index),可以通过数组的索引访问到数组中的元素。
注意
1)索引越界
int[] arr = {1,2,3};
System.out.println(arr[3]);
创建数组,赋值3个元素,数组的索引就是0,1,2,没有3索引,不能访问数组中不存在的索引,程序运 行后,将会抛出 ArrayIndexOutOfBoundsException 数组越界异常。
2)空指针异常
int[] arr = {1,2,3};
arr = null;
System.out.println(arr[0]);
arr = null 这行代码,意味着变量arr将不会在保存数组的内存地址,也就不允许再操作数组了,因此运行的时候 会抛出 NullPointerException 空指针异常
常见操作
1)获取数组长度
int[] arr={1,2,3,4,56,6};
int len =arr.length;
数组创建后,程序运行期间,长度不可改变
2)数组遍历
int[] arr = { 1, 2, 3, 4, 5 };
for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i]);
}
数组的索引是 0 到 lenght-1 ,可以作为循环的条件出现
3)数组最值
int[] arr = { 5, 15, 2000, 10000, 100, 4000 };
//定义变量,保存数组中0索引的元素
int max = arr[0];
//遍历数组,取出每个元素
for (int i = 0; i < arr.length; i++) {
//遍历到的元素和变量max比较
//如果数组元素大于max
if (arr[i] > max) {
//max记录住大值
max = arr[i];
}
}
System.out.println("数组最大值是: " + max);
实现思路:
定义变量,保存数组0索引上的元素
遍历数组,获取出数组中的每个元素 将遍历到的元素和保存数组0索引上值的变量进行比较
如果数组元素的值大于了变量的值,变量记录住新的值
数组循环遍历结束,变量保存的就是数组中的最大值
4)数组反转
int[] arr = { 1, 2, 3, 4, 5 };
/*
循环中定义变量min=0最小索引
max=arr.length‐1最大索引
min++,max‐
*/
for (int min = 0, max = arr.length ‐ 1; min <= max; min++, max‐‐) {
//利用第三方变量完成数组中的元素交换
int temp = arr[min];
arr[min] = arr[max];
arr[max] = temp;
}
// 反转后,遍历数组
for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i]);
}
实现思想:
数组最远端的元素互换位置。
实现反转,就需要将数组最远端元素位置交换
定义两个变量,保存数组的最小索引和最大索引 两个索引上的元素交换位置 最小索引++,最大索引–,
再次交换位置 最小索引超过了最大索引,数组反转操作结束
来源:CSDN
作者:菜鸟郭郭
链接:https://blog.csdn.net/qq_39273039/article/details/104316999