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

目录
相关文章
|
6天前
|
存储 前端开发 JavaScript
【前端学java】一篇文章带你精通java 中的数组(10)
【8月更文挑战第10天】一篇文章带你精通java 中的数组
9 3
【前端学java】一篇文章带你精通java 中的数组(10)
|
6天前
|
Java 索引
java中的栈(利用数组实现栈)
这篇文章通过Java代码示例介绍了如何使用数组实现栈操作,包括栈的初始化、入栈、出栈、判断栈满和空以及遍历栈的方法。
java中的栈(利用数组实现栈)
|
12天前
|
Java
Java 基础语法-面试题(54-63道)(数组+类+包)
Java 基础语法-面试题(54-63道)(数组+类+包)
30 16
|
11天前
|
Java
Java数组几道练习题
Java数组几道练习题
27 11
|
11天前
|
Java 容器
07 Java数组与数组操作(定义+遍历+排序+增删改查)(上)
07 Java数组与数组操作(定义+遍历+排序+增删改查)
28 8
|
11天前
|
Java
Java数组的2个小案例(杨辉三角分析和商品管理增删改查)
Java数组的2个小案例(杨辉三角分析和商品管理增删改查)
36 4
|
11天前
|
存储 Java API
07 Java数组与数组操作(定义+遍历+排序+增删改查)(下)
07 Java数组与数组操作(定义+遍历+排序+增删改查)
26 4
|
18天前
|
存储 算法 Java
Java零基础(1) - 从零开始学习数组
【8月更文挑战第1天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
24 1
|
6天前
|
Java
Java中 字符串,字符串数组,整型数组初始化
Java中 字符串,字符串数组,整型数组初始化
6 0
|
11天前
|
算法 Java 索引
LeetCode初级算法题:寻找数组的中心索引+x的平方根+三个数的最大乘积+Leetcode 149:直线上最多的点数 Java详解
LeetCode初级算法题:寻找数组的中心索引+x的平方根+三个数的最大乘积+Leetcode 149:直线上最多的点数 Java详解
22 0