java实现稀疏矩阵的压缩与解压的方法

网友投稿 329 2022-08-17


java实现稀疏矩阵的压缩与解压的方法

目录任务要求思路分析稀疏矩阵的压缩稀疏矩阵的解压代码实现

任务要求

把棋盘当作一个稀疏矩阵,0表示没棋,1表示黑棋,2表示蓝棋。

把该稀疏矩阵压缩以三元组形式表示并以文件形式保存,再写另一个程序读取文件中的信息把压缩后的三元组还原成原来的稀疏矩阵。

其中三元组的第一行用来存储原始稀疏矩阵的行数、列数和有效的数据个数,其余行用来存储有效的非0数据

思路分析

稀疏矩阵的压缩

遍历原始的稀疏矩阵,得到有效的数据个数sum根据sum创建三元组new int [sum+1] [3](即sum+1行3列的二维数组)将二维数据的有效数据存入三元组中

稀疏矩阵的解压

先读取三元组的第一行,根据第一行的数据创建一个二维数组再读取三元组的后面几行,并赋值给该二维数组即可

代码实现

稀疏矩阵的压缩

package zone.lxy.sparsearray;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.ObjectOutputStream;

/*

* 把稀疏矩阵压缩成三元组

* *http:///

public class Compress {

public static void main(String[] args) throws IOException {

// 创建一个稀疏矩阵11*11

// cAbntai0表示没有棋子

// 1表示黑子

// 2表示白子

int[][] chessArr1 = new int[11][11];

chessArr1[1][2] = 1;

chessArr1[2][3] = 2;

// 输出原始的稀疏矩阵

System.out.println("原始的稀疏矩阵:");

for (int i = 0; i < 11; i++) {

for (int j = 0; j < 11; j++) {

System.out.print(chessArr1[i][j] + " ");

}

System.out.println();

}

// 对稀疏矩阵压缩存储

// 1.先遍历稀疏矩阵记录非0元素的个数

int sum = 0;

if (chessArr1[i][j] != 0) {

sum++;

}

// 2.创建对应的三元组并初始化

int[][] sparseArr = new int[sum + 1][3];

sparseArr[0][0] = 11;

sparseArr[0][1] = 11;

sparseArr[0][2] = sum;

// 3.把稀疏矩阵中的非0元素放到三元组中

int count = 1;

sparseArr[count][0] = i;

sparseArr[count][1] = j;

sparseArr[count][2] = chessArr1[i][j];

count++;

// 输出生成的三元组

System.out.println("得到压缩后的三元组:");

for (int i = 0; i < sparseArr.length; i++) {

System.out.printf("%-2d %-2d %-2d\n", sparseArr[i][0], sparseArr[i][1], sparseArr[i][2]);

// 把该三元组以文件形式保存起来,压缩完成

FileOutputStream fos = new FileOutputStream("map.data");

ObjectOutputStream oos = new ObjectOutputStream(fos);

oos.writeObject(sparseArr);

oos.close();

fos.close();

}

}

// 输出结果

原始的稀疏矩阵:

0 0 0 0 0 0 0 0 0 0 0

0 0 1 0 0 0 0 0 0 0 0

0 0 0 2 0 0 0 0 0 0 0

得到压缩后的三元组:

11 11 2

1 2 1

2 3 2

稀疏矩阵的解压

package zone.lxy.sparsearray;

import java.io.FileInputStream;

import java.io.IOException;

import java.io.ObjectInputStream;

/*

* 把三元组还原成稀疏矩阵

* */

public class DeCompress {

public static void main(String[] args) throws IOException, ClassNotFoundException {

// 读取文件并赋值

FileInputStream fis = new FileInputStream("map.data");

ObjectInputStream ois = new ObjectInputStream(fis);

int[][] sparseArr = (int[][]) ois.readObject();

ois.close();

fis.close();

// 输出文件中的存储的三元组

System.out.println("得到压缩后的三元组:");

for (int i = 0; i < sparseArr.length; i++) {

System.out.printf("%-2d %-2d %-2d\n", sparseArr[i][0], sparseArr[i][1], sparseArr[i][2]);

}

// 先读取三元组的第一行,根据第一行数据创建原始的稀疏矩阵

int row = sparseArr[0][0];

int col = sparseArr[0][1];

int[][] chessArr = new int[row][col];

// 从第二行开始读取三元组并赋值给稀疏矩阵

for (int a = 1; a

int i = sparseArr[a][0];

int j = sparseArr[a][1];

int val = sparseArr[a][2];

chessArr[i][j] = val;

}

// 输出解压后的稀疏矩阵

System.out.println("解压后的二维数组:");

for (int[] i : chessArr) {

for (int item : i) {

System.out.printf("%d ", item);

}

System.out.println();

}

}

}

// 输出结果

得到压缩后的三元组:

11 11 2

1 2 1

2 3 2

解压后的二维数组:

0 0 0 0 0 0 0 0 0 0 0

0 0 1 0 0 0 0 0 0 0 0

0 0 0 2 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

int i = sparseArr[a][0];

int j = sparseArr[a][1];

int val = sparseArr[a][2];

chessArr[i][j] = val;

}

// 输出解压后的稀疏矩阵

System.out.println("解压后的二维数组:");

for (int[] i : chessArr) {

for (int item : i) {

System.out.printf("%d ", item);

}

System.out.println();

}

}

}

// 输出结果

得到压缩后的三元组:

11 11 2

1 2 1

2 3 2

解压后的二维数组:

0 0 0 0 0 0 0 0 0 0 0

0 0 1 0 0 0 0 0 0 0 0

0 0 0 2 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0 0


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:SpringBoot各种参数校验的实例教程
下一篇:Java数据结构之平衡二叉树的实现详解
相关文章

 发表评论

暂时没有评论,来抢沙发吧~