数组之二维数组
二维数组的定义
格式:
int[][] arr = new int[3][4];
定义一个二维数组,这个数组是由3个一维数组组成,每个一维数组的长度是4;
也就是说,上面这个二维数组存储了12个数据
System.out.println(arr);这个打印出来的是二维数组的存储地址
System.out.println(arr[1]);这个打印出来的是二维数组中的第二个一维数组的存储地址
System.out.println(arr[2][3]);系统打印出来的是第三个一维数组中的索引3,结果为0;
System.out.println(arr[2][4]);越界异常;
最简单的二维数组格式
int[][] arr = {{1,2,3},{2,3,4,5},{2,1},{2,0,4,6,7,8,9,6}};
二维数组的遍历
二维数组中,存储的每个一维数组的长度是不一样的
所以变成思想:
先用for循环,遍历二维数组;(外循环)
再用for循环,遍历一维数组;(内循环)
运用二维数组的代码如下
package 数组;
import java.util.Scanner;
public class LY2数组 {
public static void main(String[] args) {
int[][] a = new int[3][3];
shuru(a);
shuchu(a);
int[] s = sum(a);
for (int i = 0; i < s.length; i++) {
System.out.println(s[i]);
}
int[] m = zuida(a);
for (int i = 0; i < s.length; i++) {
System.out.println(m[i]);
}
}
static void shuru(int[][] a) {
Scanner scanner = new Scanner(System.in);
for (int i = 0; i < a.length; i++) {
for (int j = 0; j < a[i].length; j++) {
a[i][j] = scanner.nextInt();
}
}
}
static void shuchu(int[][] a) {
for (int i = 0; i < a.length; i++) {
for (int j = 0; j < a[i].length; j++) {
System.out.print(a[i][j] + " ");
}
System.out.println();
}
}
static int[] sum(int[][] a) {
int[] sum = new int[a.length];
for (int i = 0; i < a.length; i++) {
for (int j = 0; j < a[i].length; j++) {
sum[i] += a[i][j];
}
}
return sum;
}
static int[] zuida(int[][] a) {
int[] max = new int[a.length];
for (int i = 0; i < a[0].length; i++) {
for (int j = 0; j < a.length; j++) {
if (a[i][j] > max[i]) {
max[i] = a[i][j];
}
}
}
return max;
}
}