Day14 稀疏数组

Day14 稀疏数组

  • 需求:编写五子棋游戏中,有存盘退出和续上盘的功能
  • 分析问题:因为该二维数组的很多值是默认值0
  • 解决:稀疏数组

稀疏数组介绍

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

  • 稀疏数组的处理方式是:

    • 记录数组一共有几行几列,有多少个不同值
    • 把具有不同值的元素、行列、值、记录在一个小规模的数组中,从而缩小程序的规模
  • 如下图:上边是原始数组,下边是稀疏数组

0 0 0 22 0 0 15
11 0 0 0 0 17 0
0 0 0 -6 0 0 0
0 0 0 0 0 39 0
0 91 0 0 0 0 0
0 0 28 0 0 0 0
行(row) 列(col) 值(value)
[0] 6 7 8
[1] 0 3 22
[2] 0 6 15
[3] 1 1 11
[4] 1 5 17
[5] 2 3 -6
[6] 3 5 39
[7] 4 0 91
[8] 5 2 28
package JAVA.Day.Array;

public class Array8 {
    public static void main(String[] args) {
//1.创建一个二维数组11*11  0:没有棋子  1:黑棋  2:白棋
        int[][] array1 = new int[11][11];
        array1[1][2] = 1;  //第一颗棋子的位置是1,2
        array1[2][3] = 1;  //第二颗棋子的位置是2,3

        //输出原始的数组(打印棋盘)
        System.out.println("输出原始的数组");
        for (int[] ints : array1) {    //用了for-each语句(array1.for),这里的for打印的是一维数组
            for (int anInt : ints) {    //这里也用了for-each语句(ints.for),这里的for打印的是二维数组
                System.out.print(anInt + "\t");
            }
            System.out.print("\n");
        }
        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);

//2.创建一个稀疏数组的数组
        int[][] array2 = new int[sum + 1][3];  //表头
        array2[0][0] = 11;           //给表头的“行”赋值
        array2[0][1] = 11;           //给表头的“列”赋值
        array2[0][2] = 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++;
                    array2[count][0] = i;
                    array2[count][1] = j;
                    array2[count][2] = array1[i][j];
                }
            }
        }

        //输出稀疏数组
        System.out.println("稀疏数组为:");
        for (int i = 0; i < array2.length; i++) {
            System.out.println(array2[i][0] + "\t" + array2[i][1] + "\t" + array2[i][2]);
        }
        System.out.println("==================================");

        System.out.println("还原");
        //读取稀疏数组
        int[][] array3 = new int[array2[0][0]][array2[0][1]];
        //给其中的元素还原它的值
        for (int i = 1; i < array2.length; i++) {
            array3[array2[i][0]][array2[i][1]] = array2[i][2];
        }
        //打印
        System.out.println("输出还原数组");
        for (int[] ints : array3) {
            for (int anInt : ints) {
                System.out.print(anInt + "\t");
            }
            System.out.print("\n");
        }
    }
}
posted @ 2025-07-16 00:11  巫山独白  阅读(7)  评论(0)    收藏  举报