Java稀疏数组

简介: 1.稀疏数组2.稀疏数组的使用2.1 二维数组转换为稀疏数组2.2 稀疏数组转换为二维数组

1.稀疏数组


稀疏数组(Sparse Array):当一个数组中的大部分元素为相同的值,可使用稀疏数组来保存该数组,可以将稀疏数组看做是普通数组的压缩


例如


d33ba269edfc457385c61d99a25f9d3f.png


数组arr中许多值为0,若对二维数组直接进行存储,则会存储许多相同的数值0,造成空间的浪费,此时,我们可以用稀疏数组对其进行存储


2.稀疏数组的使用


要对二维数组进行存储,我们需要知道二维数组的行和列、不同数值的数量以及不同元素的位置和值

稀疏数组的第一行,存放二维数组arr的行数、列数、不同数值的数量sum

后面几行,存放不同值元素在二维数组arr中的行、列、数值


48d4bc49979444569af14f7bfd2d2a69.png


代码实现


创建二维数组


int[][] arr=newint[6][5];
arr[1][0] =1;
arr[1][3] =6;
arr[4][3] =2;


2.1 二维数组转换为稀疏数组

(1)遍历二维数组,确定不同元素的个数sum


intsum=0;
for (inti=0; i<arr.length; i++) {
for (intj=0; j<arr[0].length; j++) {
if(arr[i][j] !=0){
sum++;
                }
            }
        }

(2)根据sum创建稀疏数组


int[][] sparseArr=newint[sum+1][3];

(3) 遍历二维数组,对稀疏数组进行赋值


//稀疏数组的第一行分别存放二维数组的行数、列数以及不同元素的个数sparseArr[0][0] =arr.length;
sparseArr[0][1] =arr[0].length;
sparseArr[0][2] =sum;
//再对不同元素进行存储intk=0;
for (inti=0; i<arr.length; i++) {
for (intj=0; j<arr[0].length; j++) {
if(arr[i][j] !=0){
k++;
//分别存放不同元素的行、列以及数值sparseArr[k][0] =i;
sparseArr[k][1] =j;
sparseArr[k][2] =arr[i][j];
                }
            }
        }

2.2 稀疏数组转换为二维数组

(1)创建二维数组


int[][] arr1=newint[sparseArr[0][0]][sparseArr[0][1]];

(2)遍历稀疏数组, 对不同值元素进行赋值


//遍历稀疏数组,对不同值元素进行赋值for (inti=1; i<sparseArr.length; i++) {
arr1[sparseArr[i][0]][sparseArr[i][1]] =sparseArr[i][2];
        }


完整代码

publicclassTest {
publicstaticvoidmain(String[] args) {
//创建二维数组int[][] arr=newint[6][5];
arr[1][0] =1;
arr[1][3] =6;
arr[4][3] =2;
System.out.println("****二维数组****");
for (int[] row: arr) {
for (intdata: row) {
System.out.printf("%d ",data);
            }
System.out.println();
        }
intsum=0;
for (inti=0; i<arr.length; i++) {
for (intj=0; j<arr[0].length; j++) {
if(arr[i][j] !=0){
sum++;
                }
            }
        }
//创建稀疏数组int[][] sparseArr=newint[sum+1][3];
//稀疏数组的第一行分别存放二维数组的行数、列数以及不同元素的个数sparseArr[0][0] =arr.length;
sparseArr[0][1] =arr[0].length;
sparseArr[0][2] =sum;
//再对不同元素进行存储intk=0;
for (inti=0; i<arr.length; i++) {
for (intj=0; j<arr[0].length; j++) {
if(arr[i][j] !=0){
k++;
//分别存放不同元素的行、列以及数值sparseArr[k][0] =i;
sparseArr[k][1] =j;
sparseArr[k][2] =arr[i][j];
                }
            }
        }
System.out.println("****稀疏数组****");
for (int[] row: sparseArr) {
for (intdata: row) {
System.out.printf("%d ",data);
            }
System.out.println();
        }
//创建二维数组int[][] arr1=newint[sparseArr[0][0]][sparseArr[0][1]];
//遍历稀疏数组,对不同值元素进行赋值for (inti=1; i<sparseArr.length; i++) {
arr1[sparseArr[i][0]][sparseArr[i][1]] =sparseArr[i][2];
        }
System.out.println("****二维数组****");
for (int[] row: arr1) {
for (intdata: row) {
System.out.printf("%d ",data);
            }
System.out.println();
        }
    }
}


运行结果

7ef5788170fb4942af6d551b5da76903.png

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