Java数组之二维数组
Java中除了一维数组外,还有二维数组,三维数组等多维数组。本文以介绍二维数组来了解多维数组。
1.二维数组的基础
二维数组的定义:二维数组就是数组的数组,数组里的元素也是数组。
二维数组表示行列二维结构
2.二维数组的声明
二维数组有三种声明方式。
2.1.根据二维数组的定义
1 import java.util.Arrays; 2 public class Test05{ 3 public static void main(String[] args){ 4 //根据二维数组的定义 5 //二维数组 6 //int[] arr; 7 //(int[])[]arr; 8 9 //声明 10 int[][] arr; 11 //初始化一个能存三个一维数组的二维数组 12 arr = new int[3][]; 13 //赋值 14 int[] arr1 = {3,4,5,7}; 15 int[] arr2 = {3,4,6}; 16 int[] arr3 = {3,4,7,8}; 17 18 arr[0] = arr1; 19 arr[1] = arr2; 20 arr[2] = arr3; 21 22 System.out.print(arr); 23 System.out.println(Arrays.toString(arr)); 24 } 25 }
此时arr = new int[3][];只分配了二维数组的空间,一维数组没有分配空间。
2.2.声明一个规则的二维数组
1 import java.util.Arrays; 2 public class Test06{ 3 public static void main(String[] args){ 4 //声明一个规则的二维数组,3行4列 5 int[][] arr = new int[3][4]; 6 arr[0][0]=10; 7 arr[0][1]=10; 8 arr[0][2]=10; 9 arr[0][3]=10; 10 11 arr[1][0]=10; 12 arr[1][1]=10; 13 arr[1][2]=10; 14 arr[1][3]=10; 15 16 arr[2][0]=10; 17 arr[2][1]=10; 18 arr[2][2]=10; 19 arr[2][3]=10; 20 21 System.out.println(Arrays.toString(arr)); 22 } 23 }
此时,二维数组已经分配好空间,同时一维也分配好空间。
2.3.当已知二维数组元素的数值,可以考虑字面量声明
1 import java.util.Arrays; 2 public class Test02{ 3 public static void main(String[] args){ 4 //已知数组元素,二维数组的声明方式 5 int[][] arr ={ 6 {10,20,30,40}, 7 {100,200,300}, 8 {1000,2000,3000,4000} 9 }; 10 System.out.println(Arrays.toString(arr)); 11 } 12 }
3.二维数组的遍历
1 import java.util.Arrays; 2 public class Test02{ 3 public static void main(String[] args){ 4 //已知数组元素,二维数组的声明方式 5 int[][] arr ={ 6 {10,20,30,40}, 7 {100,200,300}, 8 {1000,2000,3000,4000} 9 }; 10 //遍历二维数组 11 for(int i = 0;i<arr.length;i++){ //行数遍历二维数组 12 for(int j = 0;j<arr[i].length;j++){ //列的元素 13 System.out.print(arr[i][j] + "\t"); 14 } 15 System.out.println(); 16 } 17 } 18 }
总结:
二维数组是行列结构,使用双层for循环,外层for用于控制行,内层for用于控制列=>行列结构 => 双层for遍历。
以上,我们就了解完二维数组的基本知识了。
此外,在学习数组知识的时候有一些细节是需要我们注意的,就是基本数据类型和引用数据类型赋值的区别。接下来我们通过一些小练习来讲解一下基本数据类型和引用数据类型赋值的区别。
4.基本数据类型和引用数据类型赋值的区别
1 import java.util.Arrays; 2 public class Test09{ 3 public static void main(String[] args){ 4 5 // 基本数据类型的赋值 6 int a = 10; 7 int b; 8 b = a; 9 // a? b? 10 b = 20; 11 // a? b? 12 13 // 引用数据类型的赋值 14 int[] arr = {1,3,5}; 15 int[] arr2 = arr; 16 arr2[0] = 100; 17 18 System.out.println("arr:"+arr); 19 System.out.println("arr2:"+arr2); 20 System.out.println("arr[0]:"+arr[0]); 21 } 22 }
通过图解来加深理解。
总结:
基本数据类型赋值时,复制的是值
引用数据类型赋值时,复制的是引用。
5.Arrays类
在上面,我们运用了Array类,关于Array类我们也来讲解一下关于Array类的用法。
jdk中为了便于开发,给开发者提供了Arrays类,其中包含了很多数组的常用操作。例如快速输出、排序、查找等。
5.1常用用法
1 import java.util.Arrays; 2 public class Test00{ 3 public static void main(String[] args){ 4 //Arrays类的常用方法 5 int[] arr = {4,3,7,8}; 6 //【1】数组的字符串形式 7 String str = Arrays.toString(arr); 8 System.out.println(str); 9 10 //【2】sort对数组进行排序(只能是升序)->内部使用快速排序 11 Arrays.sort(arr); 12 System.out.println(Arrays.toString(arr)); 13 14 /*【3】fill 填充数组 Arrays.fill(arr,fromIndex,toIndex,填充的值); 15 *toIndex:结束下标不包含,(含头不含尾) 16 */ 17 //Arrays.fill(arr,0,4,2); 18 //System.out.println(Arrays.toString(arr)); 19 20 //【4】equals(arr1,arr2)判断两个数组是否相等。 21 //数组相等的条件是:a.长度相等 b.两个数组对应位置的元素相等 22 int[] arr3 = {3,4,7,8}; 23 System.out.println(Arrays.equals(arr,arr3)); 24 } 25 }
5.2.二分法查找
1 import java.util.Arrays; 2 public class Test03{ 3 public static void main(String[] args){ 4 //二分法查找,二分法查找必须是有序的数组,如果找到返回索引; 5 //源码 6 /*private static int binarySearch0(long[] a, int fromIndex, int toIndex, 7 long key) { 8 int low = fromIndex; 9 int high = toIndex - 1; 10 11 while (low <= high) { 12 int mid = (low + high) >>> 1; //除2 13 long midVal = a[mid]; 14 15 if (midVal < key) 16 low = mid + 1; 17 else if (midVal > key) 18 high = mid - 1; 19 else 20 return mid; // key found 21 } 22 return -(low + 1); // key not found. low为插入点,即Key应该放在数组中的位置 23 } 24 */ 25 26 /*二分法查找数组的元素(有序的数组),返回的是元素的下标,binarySearch(arr,fromIndex,toIndex,key) 27 *a - 要搜索的数组 28 key - 要搜索的值 29 */ 30 int[] arr = {1,2,4,5,7,8}; 31 int a = Arrays.binarySearch(arr,4);//找4的索引 32 System.out.println("要找的值的位置为:"+a); 33 } 34 }
5.3数组的复制
1 import java.util.Arrays; 2 public class Test01{ 3 public static void main(String[] args){ 4 //数组的复制 5 int[] arr = {1,3,4,6,8}; 6 int[] newArr = Arrays.copyOf(arr,5);//复制到一个新数组 7 System.out.println(Arrays.toString(newArr)); 8 9 //copyOfRange(arr,from,to) from:开始的位置(包含) to:目标位置(不包含) 含头不含尾 10 11 int[] newArr2 = Arrays.copyOfRange(arr,1,3); 12 System.out.println(Arrays.toString(newArr2)); 13 14 //其中System也提供了赋值数组的方法。 15 //arraycopy(object str,int srcPos,object dest,int destPos,int length) 16 /* 17 *arraycopy(srcArr,srcPos,destArr,destPos,len) 18 srcArr:要复制的源数组 19 srcPos:从srcArr的srcPos位置开始复制 20 destArr:复制到的目标数组 21 destPos:目标数组从destPos开始存放 22 len:从源数组中复制len个长度 23 */ 24 int[] arr2 = new int[arr.length]; 25 System.arraycopy(arr,1,arr2,0,4); 26 System.out.println(Arrays.toString(arr2)); 27 } 28 }