目录
1. 数组的概述
2. 数组声明及创建
声明数组:
创建数组:
java内存分析:
数组的四个基本特点:
3.数组使用
4.二维数组
5.稀疏数组
1. 数组的概述
- 数组是相同类型数据的有序集合
概念理解:数组描述的是相同类型、按照一定的先后次序排列组合而成的的若干数据,其中,每一个数据称作一个数组元素,每个数组元素可以通过一个下标来访问。
2. 数组声明及创建 声明数组:dataType[] array; //java风格,首选
dataType array[]; //c、c++风格
创建数组:tips:1.数组元素是通过下标索引来访问的,数组下标索引从0开始
2.可以通过array.length这一属性来获取数组长度
java内存分析:举个例子:在声明数组时,会在栈中压入array这个引用类型变量,来存放array在堆里的具体地址;在创建数组时,会往堆里面开辟一个内存空间(这就是array指向的内存地址空间),存放对应的int[]对象,然后再是给int类型的变量逐一赋值。
数组的四个基本特点:- 数组的长度是确定的,数组一旦被创建,那么它的大小就不可更改。
- 数组的元素必须是相同类型的,不允许出现混合类型。
- 数组中的元素可以是基本数据类型也可以是引用类型。
- 数组变量属于引用类型,数组也可以看成是对象,数组中的每个元素相当于该对象的成员变量,而Java中对象是在堆中的,因此数组无论保存原始类型还是其它对象类型,数组对象本身是在堆中的。
1.for循环
2.for-each循环
3.数组作方法入参
4.数组作返回值
package array; public class Demo01 { public static void main(String[] args) { int[] arrays = {1,2,3,4,5}; //for-each循环,没有下标 for (int array : arrays) { System.out.println(array); } //将数组作为返回值 int[] reverse= reverse1(arrays); printArray(reverse); reverse2(arrays); printArray(arrays); } //数组作方法入参,打印数组元素 public static void printArray(int[] arrays) { for (int i = 0; i < arrays.length ; i++) { System.out.print(arrays[i]+"t"); } System.out.println(); } //反转数组1 新定义一个数组来存储反转的值 public static int[] reverse1(int[] arrays) { int[] result =new int[arrays.length]; for (int i = 0,j= arrays.length-1; i < arrays.length; i++,j--) { result[j]=arrays[i]; } return result; } //反转数组2 直接在现有的数组上进行反转 public static int[] reverse2(int[] arrays) { int start=0; int end=arrays.length-1; while (start4.二维数组 二维数组就是一个特殊的一维数组,其中每个元素都是一个一维数组,俗称套娃。
5.稀疏数组
package array; //稀疏数组 // row col value //[0] 11 11 2 //[1] 1 2 1 //[2] 2 3 2 public class Demo02 { public static void main(String[] args) { //创建一个二维数组 11*11 0:没有棋子 1:黑棋 2:白棋 int[][] array1=new int[11][11]; array1[1][2]=1; array1[2][3]=2; //输出原始数组 System.out.println("输出原始数组:"); for(int[] ints : array1) { for(int anInt : ints) { System.out.print(anInt+"t"); } System.out.println(); } //转化为稀疏数组 //1.获取有效值的个数 int sum=0; for (int i = 0; i < array1.length; i++) { for (int j = 0; j < array1[0].length; j++) { if(array1[i][j]!=0) sum++; } } System.out.println("有效值的个数:"+sum); //2.创建一个稀疏数组的数组 int[][] array2=new int[sum+1][3]; array2[0][0]=11; array2[0][1]=11; array2[0][2]=sum; //遍历二维数组,将非零的值,存放到稀疏数组中 int count=0; for (int i = 0; i < array1.length; i++) { for (int j = 0; j
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)