1、稀疏数组
代码:创建原始数组/压缩成稀疏数组/根据稀疏数组还原原数组
package array;
public class Demo08 {
public static void main(String[] args) {
//1、创建一个二维数组 11*11 0:没有棋子 1:黑棋 2:白棋
int[][] array1 = new int[11][11]; //11*11的数组每个元素的值默认是0
array1[1][2] = 1; //第1行第2列是黑棋
array1[2][3] = 1; //第2行第3列是黑棋
//输出原始数组
System.out.println("输出原始数组");
for (int[] ints : array1) {
for (int anInt : ints) {
System.out.print(anInt+"\t"); // "\t" 相当于tab键
}
System.out.println();// 换行
}
System.out.println("===================");
//转换为稀疏数组保存
//获取有效值的个数
int sum = 0;
for (int i = 0; i < 11; i++) {
for (int j = 0; j < 11; j++) {
if(array1[i][j]!=0){
sum++;
}
}
}
System.out.println("有效值的个数:"+sum);
//创建一个稀疏数组的数组
int[][] arrays2 = new int[sum+1][3]; //sum+1行 3列(存放行/列/值)
arrays2[0][0] = 11; //第1行第1列的值11代表原数组有11行
arrays2[0][1] = 11; //第1行第2列的值11代表原数组有11列
arrays2[0][2] = sum; //第1行第3列的值11代表原数组有sum个数
//遍历二维数组,将非零的值存放稀疏数组中
int count = 0;
for (int i = 0; i < array1.length; i++) {
for (int j = 0; j < array1[i].length; j++) {
if (array1[i][j]!=0){
count++;
//当遍历到不等于0的数时,为稀疏数组添加到count行
// 第count行的第一个数存放原数组array1的横坐标:i
// 第count行的第二个数存放原数组array1的纵坐标:j
// 第count行的第二个数存放值:array1[i][j]
arrays2[count][0] = i;
arrays2[count][1] = j;
arrays2[count][2] = array1[i][j];
}
}
}
//输出稀疏数组
System.out.println("=======================");
for (int i = 0; i < arrays2.length; i++) {
System.out.println(arrays2[i][0]+"\t"
+arrays2[i][1]+"\t"
+arrays2[i][2]+"\t");
}
//反向操作:根据稀疏数组还原原数组
System.out.println("============");
//读取稀疏数组
int[][] arrays3 = new int[arrays2[0][0]][arrays2[0][1]]; //创建原数组的行列
//给元素还原它的值
for (int i = 1; i <arrays2.length ; i++) {
arrays3[arrays2[i][0]][arrays2[i][1]] = arrays2[i][2];
}
//输出还原数组
System.out.println("=======================");
for (int[] ints : arrays3) {
for (int anInt : ints) {
System.out.print(anInt+"\t"); // "\t" 相当于tab键
}
System.out.println();// 换行
}
}
}