滚雪球学Java(32):如何理解和实现稀疏数组

简介: 【5月更文挑战第7天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!

🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!!


前言

在实际开发中,我们常会遇到占用内存过大的问题,如何在规避内存浪费的情况下,存储大量数据是我们需要考虑的问题。本篇文章将介绍一种特殊的数据结构——稀疏数组,帮助开发者解决存储数据时占用内存过大的问题,提高程序的效率。

摘要

稀疏数组是一种特殊的二维数组,用于存储大量数据时占用内存过大的问题。稀疏数组的存储方式是将非零元素及其下标存储起来,其余元素均默认为0。本文将介绍稀疏数组的概念、实现方法以及测试用例,帮助读者更好地理解和应用稀疏数组。

稀疏数组

概念

稀疏数组是指大部分元素为0或者同一值的二维数组。在实际应用中,二维数组非零元素占比较小,而且同一值的元素会重复出现,这就导致了存储空间的浪费。例如,一个10000*10000的数组,只有100个元素是非零元素,其他的元素都是0,这样存储的话会占用非常大的存储空间。而使用稀疏数组可以有效地解决这个问题。

稀疏数组的存储方式是将二维数组的非零元素及其下标存储起来,其中第一行存储原始二维数组的行数、列数及非零元素个数;接下来每行都存储一个非零元素的行数、列数及值。

稀疏数组VS原始数组

稀疏数组是一种特殊的数组,它可以用来表示原始数组中大部分元素都是相同值的情况。稀疏数组可以节省存储空间,但也存在一些缺点。以下是稀疏数组对比原始数组的优缺点:

优点:

  1. 节省空间。稀疏数组只存储非零元素及其位置信息,而原始数组需要存储每个元素的数值和位置信息。

  2. 更快的存取速度。由于稀疏数组只存储非零元素及其位置信息,所以查找某个元素的时间更短。

缺点:

  1. 转换成稀疏数组需要额外的处理时间。如果原始数组中非零元素的数量相对较少,转换成稀疏数组需要花费一定的时间。

  2. 稀疏数组的处理不如原始数组灵活。原始数组可以直接进行大量的操作,而稀疏数组需要先转换成原始数组才能进行操作。

综上所述,稀疏数组在存储大规模数据时具有明显的优势,但在某些情况下,它的转换和处理可能会带来额外的时间和空间成本。

实现方法

下面我们来看一下如何通过Java代码实现稀疏数组。

创建原始二维数组

我们首先需要创建一个原始二维数组,这里以一个五子棋游戏的棋盘为例,创建一个11*11的二维数组,用于存储棋子的位置。其中,0表示没有棋子,1表示黑子,2表示白子。

int[][] chessBoard = new int[11][11];
chessBoard[1][2] = 1;
chessBoard[2][3] = 2;
// 输出原始二维数组
for (int[] row : chessBoard) {
   
    for (int data : row) {
   
        System.out.print(data + " ");
    }
    System.out.println();
}

输出结果:

0 0 0 0 0 0 0 0 0 0 0 
0 0 1 0 0 0 0 0 0 0 0 
0 0 0 2 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0

将二维数组转为稀疏数组

我们需要将上面的二维数组转换为一个稀疏数组,实现代码如下:

int sum = 0;
for (int[] row : chessBoard) {
   
    for (int data : row) {
   
        if (data != 0) {
   
            sum++;
        }
    }
}
int[][] sparseArray = new int[sum + 1][3];
sparseArray[0][0] = 11;
sparseArray[0][1] = 11;
sparseArray[0][2] = sum;
int count = 0;
for (int i = 0; i < 11; i++) {
   
    for (int j = 0; j < 11; j++) {
   
        if (chessBoard[i][j] != 0) {
   
            count++;
            sparseArray[count][0] = i;
            sparseArray[count][1] = j;
            sparseArray[count][2] = chessBoard[i][j];
        }
    }
}
// 输出稀疏数组
for (int[] row : sparseArray) {
   
    for (int data : row) {
   
        System.out.print(data + " ");
    }
    System.out.println();
}

输出结果:

11 11 2 
1 2 1 
2 3 2

可以看到,输出的结果是一个3*3的稀疏数组,第一行表示原始二维数组的行数、列数及非零元素个数,接下来的两行分别表示非零元素的位置及其值。

将稀疏数组转为原始二维数组

我们可以通过上面构造的稀疏数组,将其转换为原始二维数组,代码如下:

int[][] chessBoard2 = new int[sparseArray[0][0]][sparseArray[0][1]];
for (int i = 1; i < sparseArray.length; i++) {
   
    chessBoard2[sparseArray[i][0]][sparseArray[i][1]] = sparseArray[i][2];
}
// 输出转换后的原始二维数组
for (int[] row : chessBoard2) {
   
    for (int data : row) {
   
        System.out.print(data + " ");
    }
    System.out.println();
}

输出结果:

0 0 0 0 0 0 0 0 0 0 0 
0 0 1 0 0 0 0 0 0 0 0 
0 0 0 2 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0 0 0

我们可以看到,转换后的原始二维数组与之前创建的二维数组完全一致。

附录源码

  如上涉及所有源码均已上传同步在Gitee,提供给同学们一对一参考学习,辅助你更迅速的掌握。

☀️建议/推荐你


  无论你是计算机专业的学生,还是对编程有兴趣的小伙伴,都建议直接毫无顾忌的学习此专栏「滚雪球学Java」,bug菌郑重承诺,凡是学习此专栏的同学,均能获取到所需的知识和技能,全网最快速入门Java编程,就像滚雪球一样,越滚越大,指数级提升。

目录
相关文章
|
26天前
|
存储 缓存 算法
Java 数组
【10月更文挑战第19天】Java 数组是一种非常实用的数据结构,它为我们提供了一种简单而有效的方式来存储和管理数据。通过合理地使用数组,我们能够提高程序的运行效率和代码的可读性。更加深入地了解和掌握 Java 数组的特性和应用,为我们的编程之旅增添更多的精彩。
31 4
|
26天前
|
存储 缓存 算法
提高 Java 数组性能的方法
【10月更文挑战第19天】深入探讨了提高 Java 数组性能的多种方法。通过合理运用这些策略,我们可以在处理数组时获得更好的性能表现,提升程序的运行效率。
22 2
|
1月前
|
存储 Java
Java“(array) <X> Not Initialized” (数组未初始化)错误解决
在Java中,遇到“(array) &lt;X&gt; Not Initialized”(数组未初始化)错误时,表示数组变量已被声明但尚未初始化。解决方法是在使用数组之前,通过指定数组的大小和类型来初始化数组,例如:`int[] arr = new int[5];` 或 `String[] strArr = new String[10];`。
|
1月前
|
存储 Java
什么是带有示例的 Java 中的交错数组?
什么是带有示例的 Java 中的交错数组?
44 9
|
1月前
|
Java
Java数组动态扩容和动态缩减
Java数组动态扩容和动态缩减
22 3
|
1月前
|
存储 算法 Java
Java一分钟之-数组的创建与遍历
数组作为Java中存储和操作一组相同类型数据的基本结构,其创建和遍历是编程基础中的基础。通过不同的创建方式,可以根据实际需求灵活地初始化数组。而选择合适的遍历方法,则可以提高代码的可读性和效率。掌握这些基本技能,对于深入学习Java乃至其他编程语言的数据结构和算法都是至关重要的。
26 6
|
1月前
|
存储 Java 程序员
【一步一步了解Java系列】:何为数组,何为引用类型
【一步一步了解Java系列】:何为数组,何为引用类型
23 1
|
1月前
|
存储 XML Java
如何在 Java 中将常见文档转换为 PNG 图像数组
如何在 Java 中将常见文档转换为 PNG 图像数组
14 1
|
1月前
|
存储 安全 Java
Java数组(Arrays)详解
Java 中的数组是一种用于存储固定数量同类型数据的高效数据结构,支持连续内存存储和随机访问。数组可以声明并初始化,通过索引访问和修改元素,获取长度,使用循环遍历,支持多维形式,并可通过 `Arrays` 类的方法进行复制和排序。数组具有固定大小和类型安全的特点,但需注意越界等问题。灵活运用数组能显著提升编程效率。
|
1月前
|
存储 算法 Java
带你学习java的数组军队列
带你学习java的数组军队列
35 0