稀疏数组:
当一个二维数组中大部份的值为0,或者为同一值的时候,可以用稀疏数组来保存
实现思路:
记录二维数组有多少行多少列、多少个不同的值
把不同的值按照所在行列,记录在一个规模较小的数组中
举例:
11×11的二维数组:
对应的稀疏数组:
其中,第一行分别为,原二维数组总行数、总列数、不为0的数的个数
之后几行的每一列分别代表所在行、所在列、值
二维数组转稀疏数组实现思路:
1. 遍历二维数组,得到非0数据的个数
2. 创建对应的稀疏数组
3. 再次遍历二维数组,将非0的值存放到稀疏数组中
稀疏数组恢复二维数组实现思路:
1. 读取稀疏数组的第一行,根据第一行的数据,创建对应的二维数组
2. 读取稀疏数组后几行的数据,赋值给二维数组
代码实现:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
//稀疏数组 public class SparseArray { public static void main(String[] args) { //创建一个原始的二维数组11 * 11 int [][] chessArr = new int [ 11 ][ 11 ]; chessArr[ 1 ][ 2 ] = 1 ; chessArr[ 2 ][ 3 ] = 2 ; chessArr[ 4 ][ 5 ] = 2 ; //输出原始的二维数组 for ( int [] row : chessArr) { for ( int i : row) { System.out.printf( "%d\t" , i); } System.out.println(); } //二维数组转稀疏数组 //首先遍历二维数组,得到非0数据的个数 int sum = 0 ; for ( int i = 0 ; i < 11 ; i++) { for ( int j = 0 ; j < 11 ; j++) { if (chessArr[i][j] != 0 ) { sum++; } } } //创建对应的稀疏数组 int [][] sparseArr = new int [sum + 1 ][ 3 ]; //对稀疏数组赋值 sparseArr[ 0 ][ 0 ] = 11 ; sparseArr[ 0 ][ 1 ] = 11 ; sparseArr[ 0 ][ 2 ] = sum; //遍历二维数组,将非0的值存放到稀疏数组中 int count = 0 ; //用于记录是第几个非0数据 for ( int i = 0 ; i < 11 ; i++) { for ( int j = 0 ; j < 11 ; j++) { if (chessArr[i][j] != 0 ) { count++; sparseArr[count][ 0 ] = i; sparseArr[count][ 1 ] = j; sparseArr[count][ 2 ] = chessArr[i][j]; } } } //输出稀疏数组 for ( int i = 0 ; i < sparseArr.length; i++) { System.out.printf( "%d\t%d\t%d\t" , sparseArr[i][ 0 ], sparseArr[i][ 1 ], sparseArr[i][ 2 ]); System.out.println(); } //稀疏数组恢复二维数组 //首先读取稀疏数组的第一行,根据第一行的数据,创建原始的二维数组 int newChessArr[][] = new int [sparseArr[ 0 ][ 0 ]][sparseArr[ 0 ][ 1 ]]; //读取稀疏数组后几行的数据,赋值给二维数组 for ( int i = 1 ; i < sparseArr.length; i++) { newChessArr[sparseArr[i][ 0 ]][sparseArr[i][ 1 ]] = sparseArr[i][ 2 ]; } //输出恢复后的二维数组 //输出原始的二维数组 for ( int [] row : newChessArr) { for ( int i : row) { System.out.printf( "%d\t" , i); } System.out.println(); } } } |
输出结果:
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 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
11 11 3
1 2 1
2 3 2
4 5 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 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
总结
本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注服务器之家的更多内容!
原文链接:https://blog.csdn.net/qq_25274377/article/details/119194206