1.定义:
int[ ][ ] arr=new int[3][2];
System.out.println(arr); // [[I@e6f7d2([[代表二位数实体 后面一串为哈希值)
System.out.println(arr[0][0]); // 为0,一维数组中的元素
System.out.println(arr[0]); // [I@3eoebb ([代表时一维数组的实体)
int[][] arr = new int[3][];----表示一个包含了三个整型的一维数组的二维数组
int[][] array=new int[3][];
//明确了二维码长度,没明确具体的一维数组
System.out.println(array);// [[3eOebb
System.out.println(array[0]);// null
System.out.println(array[0][0]);// NullPointerException
4.二维数组长度:arr.length
二维数组中一维数组的长度:arr[1].length
5.二维数组的另一种表达方式:
int[ ] arr ={{23,32,42},{33},{42,00}};
二维数组的应用:容器中存容器,如坐标值
从控制台输入行数,打印对应的杨辉三角:
//从控制台获取行数
Scanner s = new Scanner(System.in);
int row = s.nextInt();
//根据行数定义好二维数组,由于每一行的元素个数不同,所以不定义每一行的个数
int[][] arr = new int[row][];
//遍历二维数组
for(int i = 0; i < row; i++){
//初始化每一行的这个一维数组
arr[i] = new int[i + 1];
//遍历这个一维数组,添加元素
for(int j = 0; j <= i; j++){
//每一列的开头和结尾元素为1,开头的时候,j=0,结尾的时候,j=i
if(j == 0 || j == i){
arr[i][j] = 1;
} else {//每一个元素是它上一行的元素和斜对角元素之和
arr[i][j] = arr[i -1][j] + arr[i - 1][j - 1];
}
System.out.print(arr[i][j] + "\t");
}
System.out.println();
}
8.java中的二分查找法(也可用于插入位置查找):
Arrays.binarySerrch(arr,10);
Arrays类的binarySearch()方法,可以使用二分搜索法来搜索指定的数组,以获得指定对象。该方法返回要搜索元素的索引值。binarySearch()方法提供多种重载形式,用于满足各种类型数组的查找需要。