1、稀疏数组

代码:创建原始数组/压缩成稀疏数组/根据稀疏数组还原原数组

package array;

public class Demo08 {
    public static void main(String[] args) {
        //1、创建一个二维数组 11*11   0:没有棋子  1:黑棋  2:白棋
        int[][] array1 = new  int[11][11];  //11*11的数组每个元素的值默认是0
        array1[1][2] = 1; //第1行第2列是黑棋
        array1[2][3] = 1; //第2行第3列是黑棋

        //输出原始数组
        System.out.println("输出原始数组");

        for (int[] ints : array1) {
            for (int anInt : ints) {
                System.out.print(anInt+"\t"); // "\t" 相当于tab键

            }
            System.out.println();// 换行
        }


        System.out.println("===================");
        //转换为稀疏数组保存
        //获取有效值的个数
        int sum = 0;
        for (int i = 0; i < 11; i++) {
            for (int j = 0; j < 11; j++) {
                if(array1[i][j]!=0){
                    sum++;

                }
            }
            
        }
        System.out.println("有效值的个数:"+sum);


        //创建一个稀疏数组的数组
        int[][] arrays2 = new int[sum+1][3]; //sum+1行 3列(存放行/列/值)
        arrays2[0][0] = 11; //第1行第1列的值11代表原数组有11行
        arrays2[0][1] = 11; //第1行第2列的值11代表原数组有11列
        arrays2[0][2] = sum;  //第1行第3列的值11代表原数组有sum个数

        //遍历二维数组,将非零的值存放稀疏数组中
        int count = 0;
        for (int i = 0; i < array1.length; i++) {
            for (int j = 0; j < array1[i].length; j++) {
                if (array1[i][j]!=0){
                   count++;
                    //当遍历到不等于0的数时,为稀疏数组添加到count行
                    // 第count行的第一个数存放原数组array1的横坐标:i
                    // 第count行的第二个数存放原数组array1的纵坐标:j
                    // 第count行的第二个数存放值:array1[i][j]
                   arrays2[count][0] = i;
                   arrays2[count][1] = j;
                   arrays2[count][2] = array1[i][j];

                }

            }
            
        }

        //输出稀疏数组
        System.out.println("=======================");

        for (int i = 0; i < arrays2.length; i++) {
            System.out.println(arrays2[i][0]+"\t"
            +arrays2[i][1]+"\t"
            +arrays2[i][2]+"\t");

        }


        //反向操作:根据稀疏数组还原原数组
        System.out.println("============");
        //读取稀疏数组
        int[][] arrays3 = new int[arrays2[0][0]][arrays2[0][1]]; //创建原数组的行列

        //给元素还原它的值
        for (int i = 1; i <arrays2.length ; i++) {
            arrays3[arrays2[i][0]][arrays2[i][1]] = arrays2[i][2];
        }

        //输出还原数组
        System.out.println("=======================");
        for (int[] ints : arrays3) {
            for (int anInt : ints) {
                System.out.print(anInt+"\t"); // "\t" 相当于tab键

            }
            System.out.println();// 换行
        }
    }
}
Posted on 2021-11-05 18:08  阿黎~  阅读(15)  评论(0编辑  收藏  举报