二维数组与稀疏数组转换(java)

简介: 二维数组与稀疏数组转换(java)

一、什么是稀疏数组

稀疏数组:是一个数组,他的作用是将二维数据保存的值进行优化,减小储存数据的大小。


格式:稀疏素组是一个(n+1)*3的二维数组,其中n表示二维数组中有多少个不同的值。稀疏数组,第一行保存,二维数据的行、列、不同的值得个数;剩余行保存不同值的坐标、值;


举例:


如下数组为一个11*11的二维数组,有3个位置不是0,所以n为3。此例中保存二维数组需要保存11*11个数字,保存稀疏数组需要4*3个。


二维数组:

1 0 0 1 0 0 0 0 0 0 0 
0 1 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 0 0 
0 0 0 0 0 0 0 0 0 0 0

稀疏数组:

11  11  3 
0 0 1 
0 3 1 
1 1 1

 

适用场景

当一个数组中大部分元素为0,或者为同一个值得数组时,可以使用稀疏数组来保存该数组;在11*11的场景中,如果不一样的数据超过39个,不适合使用稀疏数组(不考虑数据地址的细节)

二、二维数据如何转换为稀疏数组

 //    二维数组转稀疏数组
    private static int[][] array2SparsArray(int[][] array) {
        //获取二维数据行和列
        int rowLength = array.length;
        int colLength = array[0].length;
        //获取不一样的数据
        int sum = 0;
        for (int i = 0; i < rowLength; i++) {
            for (int j = 0; j < colLength; j++) {
                if (array[i][j] != 0) {
                    sum++;
                }
            }
        }
        //初始化稀疏数组
        int[][] sparsArray = new int[sum + 1][3];
        //第一行保存二维数组的大小和不一样值得个数
        sparsArray[0][0] = rowLength;
        sparsArray[0][1] = colLength;
        sparsArray[0][2] = sum;
        //遍历二维数据,将不同的值的坐标和值保存到稀疏数组
        //记录稀疏数组的行
        int count = 0;
        for (int i = 0; i < rowLength; i++) {
            for (int j = 0; j < colLength; j++) {
                if (array[i][j] != 0) {
                    count++;
                    //保存二维数组的坐标
                    sparsArray[count][0] = i;
                    sparsArray[count][1] = j;
                    //保存二维数组的值
                    sparsArray[count][2] = array[i][j];
                }
            }
        }
        return sparsArray;
    }


三、稀疏数组如何恢复为二维数组

 //    稀疏数组转二维数组
    private static int[][] sparsArray2Array(int[][] sparsArray) {
        //获取二维数据行和列
        int rowLength = sparsArray[0][0];
        int colLength = sparsArray[0][1];
        //初始化二维数组
        int[][] array = new int[rowLength][colLength];
        int sparsArrayLength = sparsArray.length;
        for (int i = 1; i < sparsArrayLength; i++) {
            //回复二维数组中不一样的值
            array[sparsArray[i][0]][sparsArray[i][1]] = sparsArray[i][2];
        }
        return array;
    }


四、完整代码并测试

 
 
public class sparsearray {
    public static void main(String[] args) {
        int[][] array1 = new int[11][11];
        array1[0][0] = 1;
        array1[1][1] = 1;
        array1[0][3] = 1;
        System.out.println("打印二维数组");
        printArray(array1);
        int[][] sparsArray = array2SparsArray(array1);
        System.out.println("打印二维数组转换后的稀疏数组");
        printArray(sparsArray);
        System.out.println("打印稀疏数组回复后的二维数据");
        int[][] array2 = sparsArray2Array(sparsArray);
        printArray(array2);
    }
 
    //    二维数组转稀疏数组
    private static int[][] array2SparsArray(int[][] array) {
        //获取二维数据行和列
        int rowLength = array.length;
        int colLength = array[0].length;
        //获取不一样的数据
        int sum = 0;
        for (int i = 0; i < rowLength; i++) {
            for (int j = 0; j < colLength; j++) {
                if (array[i][j] != 0) {
                    sum++;
                }
            }
        }
        //初始化稀疏数组
        int[][] sparsArray = new int[sum + 1][3];
        //第一行保存二维数组的大小和不一样值得个数
        sparsArray[0][0] = rowLength;
        sparsArray[0][1] = colLength;
        sparsArray[0][2] = sum;
        //遍历二维数据,将不同的值的坐标和值保存到稀疏数组
        //记录稀疏数组的行
        int count = 0;
        for (int i = 0; i < rowLength; i++) {
            for (int j = 0; j < colLength; j++) {
                if (array[i][j] != 0) {
                    count++;
                    //保存二维数组的坐标
                    sparsArray[count][0] = i;
                    sparsArray[count][1] = j;
                    //保存二维数组的值
                    sparsArray[count][2] = array[i][j];
                }
            }
        }
        return sparsArray;
    }
 
    //    稀疏数组转二维数组
    private static int[][] sparsArray2Array(int[][] sparsArray) {
        //获取二维数据行和列
        int rowLength = sparsArray[0][0];
        int colLength = sparsArray[0][1];
        //初始化二维数组
        int[][] array = new int[rowLength][colLength];
        int sparsArrayLength = sparsArray.length;
        for (int i = 1; i < sparsArrayLength; i++) {
            //回复二维数组中不一样的值
            array[sparsArray[i][0]][sparsArray[i][1]] = sparsArray[i][2];
        }
        return array;
    }
 
    //    二维数组打印
    private static void printArray(int[][] array) {
        int rowLength = array.length;
        int colLength = array[0].length;
        for (int i = 0; i < rowLength; i++) {
            for (int j = 0; j < colLength; j++) {
                System.out.printf("%d\t", array[i][j]);
            }
            System.out.println();
        }
    }
 
 
//    稀疏数组存盘
 
//    读取稀疏数组
}
打印二维数组
1 0 0 1 0 0 0 0 0 0 0 
0 1 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 0 0 
0 0 0 0 0 0 0 0 0 0 0 
打印二维数组转换后的稀疏数组
11  11  3 
0 0 1 
0 3 1 
1 1 1 
打印稀疏数组回复后的二维数据
1 0 0 1 0 0 0 0 0 0 0 
0 1 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 0 0 
0 0 0 0 0 0 0 0 0 0 0 

相关文章
|
1月前
|
存储 Java
【编程基础知识】 分析学生成绩:用Java二维数组存储与输出
本文介绍如何使用Java二维数组存储和处理多个学生的各科成绩,包括成绩的输入、存储及格式化输出,适合初学者实践Java基础知识。
72 1
|
30天前
|
存储 缓存 算法
Java 数组
【10月更文挑战第19天】Java 数组是一种非常实用的数据结构,它为我们提供了一种简单而有效的方式来存储和管理数据。通过合理地使用数组,我们能够提高程序的运行效率和代码的可读性。更加深入地了解和掌握 Java 数组的特性和应用,为我们的编程之旅增添更多的精彩。
31 4
|
30天前
|
存储 缓存 算法
提高 Java 数组性能的方法
【10月更文挑战第19天】深入探讨了提高 Java 数组性能的多种方法。通过合理运用这些策略,我们可以在处理数组时获得更好的性能表现,提升程序的运行效率。
28 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 中的交错数组?
46 9
|
1月前
|
Java
Java数组动态扩容和动态缩减
Java数组动态扩容和动态缩减
24 3
|
1月前
|
存储 算法 Java
Java一分钟之-数组的创建与遍历
数组作为Java中存储和操作一组相同类型数据的基本结构,其创建和遍历是编程基础中的基础。通过不同的创建方式,可以根据实际需求灵活地初始化数组。而选择合适的遍历方法,则可以提高代码的可读性和效率。掌握这些基本技能,对于深入学习Java乃至其他编程语言的数据结构和算法都是至关重要的。
29 6
|
1月前
|
存储 Java 程序员
【一步一步了解Java系列】:何为数组,何为引用类型
【一步一步了解Java系列】:何为数组,何为引用类型
23 1
|
1月前
|
存储 XML Java
如何在 Java 中将常见文档转换为 PNG 图像数组
如何在 Java 中将常见文档转换为 PNG 图像数组
15 1
|
1月前
|
存储 安全 Java
Java数组(Arrays)详解
Java 中的数组是一种用于存储固定数量同类型数据的高效数据结构,支持连续内存存储和随机访问。数组可以声明并初始化,通过索引访问和修改元素,获取长度,使用循环遍历,支持多维形式,并可通过 `Arrays` 类的方法进行复制和排序。数组具有固定大小和类型安全的特点,但需注意越界等问题。灵活运用数组能显著提升编程效率。
下一篇
无影云桌面