美文网首页
稀疏数组和队列

稀疏数组和队列

作者: Cook1fan | 来源:发表于2020-11-12 07:28 被阅读0次
image.png
image.png
public class SparseArray {

    public static void main(String[] args) {
        // 二维数组 11 * 11
        // 0 = 无, 1 = 黑子,2 = 篮子
        int[][] chessArr1 = new int[11][11];
        chessArr1[1][2] = 1;
        chessArr1[2][3] = 2;
        chessArr1[4][5] = 2;
        // 输出
        for (int[] row : chessArr1) {
            for (int data : row) {
                System.out.printf("%d\t", data);
            }
            System.out.println();
        }
        // 二维转稀疏
        int sum = 0;
        for (int[] row : chessArr1) {
            for (int data : row) {
                if (data != 0) {
                    sum++;
                }
            }
        }
        System.out.println("sum = " + sum);
        // 创建稀疏
        int[][] sparseArr = new int[sum + 1][3];
        sparseArr[0][0] = 11;
        sparseArr[0][1] = 11;
        sparseArr[0][2] = sum;
        int count = 0; // 用于记录是第几个非零数据
        for (int row = 0; row < chessArr1.length; row++) {
            for (int col = 0; col < chessArr1[row].length; col++) {
                if (chessArr1[row][col] != 0) {
                    count++;
                    sparseArr[count][0] = row;
                    sparseArr[count][1] = col;
                    sparseArr[count][2] = chessArr1[row][col];
                }
            }
        }
        // 输出稀疏
        System.out.println();
        System.out.println("得到稀疏数组");
        for (int[] row : sparseArr) {
            System.out.printf("%d\t%d\t%d\t", row[0], row[1], row[2]);
            System.out.println();
        }
        System.out.println();

        // 稀疏 转 二维
        int[][] chessArr2 = new int[sparseArr[0][0]][sparseArr[0][1]];

        for (int row = 1; row < sparseArr.length; row++) {
            chessArr2[sparseArr[row][0]][sparseArr[row][1]] = sparseArr[row][2];
        }

        for (int[] row : chessArr2) {
            for (int data : row) {
                System.out.printf("%d\t", data);
            }
            System.out.println();
        }
    }
}

相关文章

  • 稀疏数组和队列

  • 02 - 稀疏数组和队列

    一、稀疏数组 1. 应用场景和介绍 编写的五子棋程序中,有存盘退出和继续上盘的功能。 该二维数组的很多值都是默认值...

  • 1.1稀疏数组和队列

    1稀疏数组 没什么好说的,挺简单的。就是讲数组转换为n行3列的二维数组。 接下来是代码 package com.a...

  • 稀疏数组SparseArray和队列

    3.1.1先看一个实际的需求 编写的五子棋程序中,有存盘退出和续上盘的功能。 因为该二维数组的很多值是默认值 0,...

  • 稀疏数组 & 环形队列

    一、稀疏数组 1、是什么?比如有一个 11 * 11 的五子棋盘,我们要用程序模拟,那肯定就是二维数组。然后用1表...

  • 稀疏数组与队列

    1.数据结构包括:线性结构和非线性结构 1.1线性结构 线性结构为最常用的数据结构,其特点是数据元素之间存在一对一...

  • (一)稀疏数组、数组队列

    一 线性结构 数据元素之间存在一对一的线性关系 顺序存储结构 顺序表中的存储元素是连续的 链式存储结构 链表中的存...

  • 数据结构

    稀疏数组 代码实现: 队列 代码实现: 环形队列 什么时候队列满:(rear+1)%maxsize == fron...

  • day01-稀疏数组和队列

    1. 稀疏数组 2.队列 特点:先入先出 rear 头 front 尾 maxsize 队列容量的最大...

  • Java数据结构之稀疏数组和队列

    稀疏数组: 应用场景,实际的需求: 编写五子棋程序中,有存档退出和保存上一句的功能。 实现: 用0代表还没有下的位...

网友评论

      本文标题:稀疏数组和队列

      本文链接:https://www.haomeiwen.com/subject/qfasbktx.html