7稀疏数组

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

下面是稀疏数组的存储规则

代码实现:

 //创建一个二维数组 
        //并建立变量num存储非零值的个数
        int[][] chessArr = new int[11][11];
        chessArr[1][2] = 1;
        chessArr[2][3] = 2;
        int num = 0;
        for (int[] row : chessArr) {
            for (int i : row) {
                System.out.printf("%d\t", i);
                if (i != 0) {
                    num++;
                }
            }
            System.out.println();
        }
        //建立稀疏数组
        int[][] sparseArray = new int[num + 1][3];
        sparseArray[0][0] = 11;
        sparseArray[0][1] = 11;
        sparseArray[0][2] = num;
        //遍历二维数组 存储非零数值
        //sum是记录行数
        int sum = 0;
        for (int i = 0; i < chessArr.length; i++) {
            for (int j = 0; j < chessArr.length; j++) {
                if (chessArr[i][j] != 0) {
                    sum++;
                    sparseArray[sum][0] = i;
                    sparseArray[sum][1] = j;
                    sparseArray[sum][2] = chessArr[i][j];
                }
            }
        }
        //遍历稀疏数组
        System.out.println("row\tcol\tval");
        for (int[] ints : sparseArray) {
            System.out.printf("%d\t%d\t%d\t\n", ints[0], ints[1], ints[2]);
        }
        //稀疏数组转变二维数组
        int newRow = sparseArray[0][0];
        int newCol = sparseArray[0][1];
        int[][] newArray = new int[newRow][newCol];
        for (int i = 1; i < sparseArray.length; i++) {
            newArray[sparseArray[i][0]][sparseArray[i][1]] = sparseArray[i][2];
        }
        
        for (int [] row:newArray){
            for (int i :row){
                System.out.printf("%d\t",i);
            }
            System.out.println();
        }