public static void main(String[] args) {
// 原始二维数组
int[][] original = new int[11][11];
// 给数组加数据
original[1][2] = 1;
original[2][3] = 2;
original[3][4] = 1;
original[9][7] = 1;
for (int[] ints : original) {
for (int anInt : ints) {
System.out.printf("%d\t", anInt);
}
System.out.println();
}
System.out.println("-------------------------");
// 创建稀疏数组,先找出原数组有多少有效元素
int sum = 0;
for (int[] ints : original) {
for (int anInt : ints) {
if (anInt != 0) {
sum++;
}
}
}
// sum为原数组有多少有效元素
// 稀疏数组的创建
int[][] sparse = new int[sum + 1][3];
// 向稀疏数组中插入元素
sparse[0][0] = 11;
sparse[0][1] = 11;
sparse[0][2] = sum;
int count = 0;
for (int i = 0; i < 11; i++) {
for (int j = 0; j < 11; j++) {
if (original[i][j] != 0) {
count++;
sparse[count][0] = i;
sparse[count][1] = j;
sparse[count][2] = original[i][j];
}
}
}
// 遍历稀疏数组输出结果
for (int[] ints : sparse) {
for (int anInt : ints) {
System.out.printf("%d\t", anInt);
}
System.out.println();
}
// 稀疏数组转二维数组
// 利用稀疏数组的第一行元素得知二维数组基本情况,有几行几列,几个有效元素
// 创建出二维数组
int[][] ints = new int[sparse[0][0]][sparse[0][1]];
// 遍历稀疏数组第一行后的数据,插入到二维数组中
for (int i = 1; i < sparse.length; i++) {
ints[sparse[i][0]][sparse[i][1]] = sparse[i][2];
}
// 输出转换后的二维数组
for (int[] anInt : ints) {
for (int i : anInt) {
System.out.printf("%d\t", i);
}
System.out.println();
}
}
二维数组与稀疏数组的转换
于 2022-01-19 21:34:48 首次发布