1、线性结构和非线性结构

线性结构:数组、队列、链表和栈
非线性结构:二维数组,多维数组,广义表,树、图

2、稀疏数组

当一个数组大部分为0,或者为同一个值时,可以用稀疏数组来保存该数组

稀疏数组的处理方法是:
1)记录数组一共有几行几列,有多少个不同的值
2)把具有不同值的元素的行列及值记录在一个小规模的数组中,从而缩小程序的规模

image.png

二维数组转 稀疏数组的思路

注意:稀疏数组的第一行为转化前的二维 数组的格式:即第一行记录有多少行,有多少列,值有多少个
1、遍历原始二维数组,得到有效数据的个数sum
2、根据sum就可以创建稀疏数组SparseArr int[sum+1][3]
3、将二维数组的有效数据存入到稀疏数组

稀疏数组转原始的二维数组的思路

1、先读取稀疏数组的第一行,根据第一行的数据,创建原始的二维数组,比如上面的chessArr2 = int[11][11]
2、在读取稀疏数组后几行的数据,并赋予原始的二维数组即可

  1. public static void main(String[] args) {
  2. // 创建一个原始的二维数组 11 * 11
  3. // 0:表示没有棋子, 1表示 黑子 2 表示 蓝子
  4. int chessArr[][] = new int[11][11];
  5. chessArr[1][2]=1;
  6. chessArr[2][3]=2;
  7. chessArr[4][5]=2;
  8. // 输出原始的二维数组
  9. for (int[] row:chessArr){
  10. for (int data:row) {
  11. System.out.printf("%d\t",data);
  12. }
  13. System.out.println();
  14. }
  15. // 1.先遍历二维数组 得到非0数据的个数
  16. int sum = 0;
  17. for (int i = 0; i < 11;i++){
  18. for (int j=0; j < 11;j++){
  19. if(chessArr[i][j] != 0){
  20. sum++;
  21. }
  22. }
  23. }
  24. // 2.创建对应的稀疏数组
  25. int sparseArr[][] = new int [sum+1][3];
  26. // 给稀疏数组赋值
  27. sparseArr[0][0] = 11;
  28. sparseArr[0][1] = 11;
  29. sparseArr[0][2] = sum;
  30. // 遍历二维数组将非0数组存入稀疏数组
  31. int count = 0;// count 用于记录是第几个非0数据
  32. for (int i = 0; i < 11;i++){
  33. for (int j=0; j < 11;j++){
  34. if(chessArr[i][j] != 0){
  35. count++;
  36. sparseArr[count][0] = i;
  37. sparseArr[count][1] = j;
  38. sparseArr[count][2] = chessArr[i][j];
  39. }
  40. }
  41. }
  42. //输出稀疏数组的形式
  43. System.out.println();
  44. System.out.println("得到的稀疏数组为:");
  45. for (int i = 0;i < sparseArr.length; i++){
  46. System.out.printf("%d\t%d\t%d\n",sparseArr[i][0],sparseArr[i][1],sparseArr[i][2]);
  47. }
  48. System.out.println();
  49. // 将稀疏数组转换为二维数组
  50. //1. 先读取稀疏数组第一行,根据第一行的数据,创建原始的二维数组
  51. int chessArr2[][] = new int[sparseArr[0][0]][sparseArr[0][1]];
  52. // 2.在读取稀疏数组后几行的数据(从第二行开始),并赋给原始的二维数组即可
  53. for(int i = 1; i<sparseArr.length; i++){
  54. chessArr2[sparseArr[i][0]][sparseArr[i][1]] = sparseArr[i][2];
  55. }
  56. // 输出恢复后的二维数组
  57. System.out.println();
  58. for (int[] row:chessArr2){
  59. for (int data:row) {
  60. System.out.printf("%d\t",data);
  61. }
  62. System.out.println();
  63. }
  64. }