02、数据结构与算法 - 基础:稀疏数组
假设创建 11 行 11 列的棋盘
0:无子 1:黑子 2:白子
将棋盘内的棋子使用稀疏队列持久化后再读取恢复存档
import org.junit.jupiter.api.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.test.context.SpringBootTest;
import java.io.*;
@SpringBootTest
class SparsearrayApplicationTests {
Logger log = LoggerFactory.getLogger(SparsearrayApplicationTests.class);
// 文件存储地址
public static final String FILE_PATH = "E:\\sparseArray.data";
@Test
void createSparseArray() throws FileNotFoundException {
// 创建 11 行 11 列的棋盘
// 0:无子 1:黑子 2:白子
int [][] arr = new int[11][11];
arr[1][3] = 1;
arr[2][4] = 2;
arr[2][2] = 1;
System.out.println("-----遍历输出原始棋盘-----");
int sum = 0; // 记录棋盘中非零数据个数
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr[i].length; j++) {
if (arr[i][j] != 0) {
sum++;
}
System.out.printf("%d\t", arr[i][j]);
}
System.out.println();
}
// 将非 0 的数据存入 sparseArray 中
// 给稀疏数组赋值 第一行为:行数 列数 值
int[][] sparseArray = new int[sum + 1][3];
sparseArray[0][0] = arr.length;
sparseArray[0][1] = arr[0].length;
sparseArray[0][2] = sum;
int count = 0; // 计算为第几个非 0 数据
// 将二维数组内存在不为零的数据存入稀疏数组
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr[i].length; j++) {
if (arr[i][j] != 0) {
count ++;
sparseArray[count][0] = i;
sparseArray[count][1] = j;
sparseArray[count][2] = arr[i][j];
}
}
}
log.info("-----遍历输出稀疏数组-----");
for (int i = 0; i < sparseArray.length; i++) {
for (int j = 0; j < sparseArray[i].length; j++) {
System.out.printf("%d\t", sparseArray[i][j]);
}
System.out.println();
}
// 存储棋盘
saveSparseArray(sparseArray, new File(FILE_PATH));
log.info("-----恢复存档棋盘数据-----");
// 读取数据返回存档棋盘数据
int[][] newArray = readSparseArray(sparseArray, new FileReader(FILE_PATH));
if (newArray != null) {
for (int i = 0; i < newArray.length; i++) {
for (int j = 0; j < newArray[i].length; j++) {
System.out.printf("%d\t", newArray[i][j]);
}
System.out.println();
}
}
}
/**
* @Desc 将数组存储到文件中
* @Param array 数组
* @Param file 存储文件
* @Return
*/
public static void saveSparseArray(int[][] array, File file){
try (FileWriter outputStream = new FileWriter(file)) {
if (file.exists()) {
file.createNewFile();
for (int i = 0; i < array.length; i++) {
for (int j = 0; j < array[i].length; j++) {
outputStream.write(array[i][j] + "\t");
}
outputStream.write("\n");
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
public static int[][] readSparseArray(int[][] array, FileReader file) {
try (BufferedReader reader = new BufferedReader(file)) {
String line = null;
String[] arr = null;
int[][] newArray = null;
int num = 0;
// 遍历读取文件内数据
while ((line = reader.readLine()) != null) {
arr = line.split("\t");
if (num == 0) {
newArray = new int[Integer.valueOf(arr[2]) + 1][3];
for (int i = 0; i < arr.length; i++) {
newArray[num][i] = Integer.valueOf(arr[i]);
}
num++;
continue;
}
for (int i = 0; i < arr.length; i++) {
newArray[num][i] = Integer.valueOf(arr[i]);
}
num++;
}
array = new int[newArray[0][0]][newArray[0][1]];
for (int i = 1; i < newArray.length; i++) {
array[newArray[i][0]][newArray[i][1]] = newArray[i][2];
}
return array;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
}