二维数组

1.1  二维数组基础
二维数组可以看成以数组为元素的数组。例如:
    int [][]  a= {{1,2},{3,4,5,6},{7,8,9}};
 二维数组表示行列二维结构。

1.2     二维数组的声明

      (1).根据二维数组的定义

     

       //【1】声明
       int[][] arr;
       // 【2】比如初始化一个能存3个一维数组的二维数组
       arr = new int[3][];
       // 【3】赋值
       int[] arr1 = {1,3,4,5};
       int[] arr2 = {1,3,4};
       int[] arr3 = {2,1,6,4};
       
       arr[0] = arr1;
       arr[1] = arr2;
       arr[2] = arr3;

 

此时arr = new int[3][];只分配了二维数组的空间,一维数组没有分配空间。

 

(2).声明一个规则的二维数组

例:

 

// 声明一个规则的二维数组,3行4列

 

   

    int[][] arr;
       arr = new int[3][4];
       arr[0][0] = 10;
       arr[0][1] = 20;
       arr[0][2] = 30;
       arr[0][3] = 40;

       arr[1][0] = 100;
       arr[1][1] = 200;
       arr[1][2] = 300;
       arr[1][3] = 400;

       arr[2][0] = 1000;
       arr[2][1] = 2000;
       arr[2][2] = 3000;
       arr[2][3] = 4000;

 

此时,二维数组已经分配好空间,同时一维也分配好空间。

(3).当已知二维数组的值数,可以考虑字面量声明

// 声明字面量二维数组

     

  int[][] arr = {
           {10,20,30,40},
           {100,200,300},
           {1000,2000,3000,4000}
       };

 

1.3    二维数组的遍历

例:

 

 1 import java.util.Arrays;
 2 public class Test08{
 3     public static void main(String[] args){
 4         
 5         // 声明字面量二维数组
 6         int[][] arr = {
 7             {10,20,30,40},
 8             {100,200,300},
 9             {1000,2000,3000,4000}
10         };
11         // System.out.println(Arrays.toString(arr));
12         
13         /*
14         for(int i=0;i<arr.length;i++){
15             int[] t = arr[i];
16             for(int j=0;j<t.length;j++){
17                 System.out.print(t[j]+"\t");
18             }
19             System.out.println();
20         }
21         */
22         
23         
24         for(int i=0;i<arr.length;i++){
25             for(int j=0;j<arr[i].length;j++){
26                 System.out.print(arr[i][j]+"\t");
27             }
28             System.out.println();
29         }
30     }
31 }

 

总结:

二维数组是行列结构,使用双层for循环,外层for用于控制行,内层for用于控制列。

行列结构 => 双层for遍历。

 

 

 

posted @ 2019-04-18 21:01  小小穿梭机^^  阅读(328)  评论(0编辑  收藏  举报