当一个数组中大部分元素为0,或者为同一个值的数组时,可以使用稀疏数组来保存该数组。
1.稀疏数组处理方法:
1)记录数组一共有几行几列,有多少个不同的值
2)把具有不同值的元素的行列及值记录在一个小规模的数组中,从而缩小程序的规模
2. 处理思路:
原始二维数组转换为稀疏数组
1)遍历原始二维数组,求出一共多少非零元素(sum)
2)创建稀疏数组,sum+1行3列
3)将二维数组的有效数据存放进稀疏数组
稀疏数组转换为原始二维数组
1)先读取稀疏数组的第一行数据,根据第一行数据,创建原始二维数组
2)读取稀疏数组后几行的数据,并赋值给原始二维数
3. 应用实例
使用稀疏数组保存未完成的棋盘:
4. 代码:
1 | package datastructure; |