二维数组与稀疏数组转换(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 

相关文章
|
2天前
|
存储 Java 索引
Java快速入门之数组、方法
### Java快速入门之数组与方法简介 #### 一、数组 数组是一种容器,用于存储同种数据类型的多个值。定义数组时需指定数据类型,如`int[]`只能存储整数。数组的初始化分为静态和动态两种: - **静态初始化**:直接指定元素,系统自动计算长度,如`int[] arr = {1, 2, 3};` - **动态初始化**:手动指定长度,系统给定默认值,如`int[] arr = new int[3];` 数组访问通过索引完成,索引从0开始,最大索引为`数组.length - 1`。遍历数组常用`for`循环。常见操作包括求和、找最值、统计特定条件元素等。
|
3月前
|
存储 Java
【编程基础知识】 分析学生成绩:用Java二维数组存储与输出
本文介绍如何使用Java二维数组存储和处理多个学生的各科成绩,包括成绩的输入、存储及格式化输出,适合初学者实践Java基础知识。
105 1
|
3天前
|
存储 Java 索引
Java基础(六):数组
Java基础(六):数组
Java基础(六):数组
|
1天前
|
存储 Java 计算机视觉
Java二维数组的使用技巧与实例解析
本文详细介绍了Java中二维数组的使用方法
25 15
|
1天前
|
存储 Java C++
Java数组:静态初始化与动态初始化详解
本文介绍了Java中数组的定义、特点及初始化方式。
25 12
|
3月前
|
存储 缓存 算法
Java 数组
【10月更文挑战第19天】Java 数组是一种非常实用的数据结构,它为我们提供了一种简单而有效的方式来存储和管理数据。通过合理地使用数组,我们能够提高程序的运行效率和代码的可读性。更加深入地了解和掌握 Java 数组的特性和应用,为我们的编程之旅增添更多的精彩。
42 4
|
3月前
|
存储 缓存 算法
提高 Java 数组性能的方法
【10月更文挑战第19天】深入探讨了提高 Java 数组性能的多种方法。通过合理运用这些策略,我们可以在处理数组时获得更好的性能表现,提升程序的运行效率。
52 2
|
3月前
|
存储 Java
Java“(array) <X> Not Initialized” (数组未初始化)错误解决
在Java中,遇到“(array) &lt;X&gt; Not Initialized”(数组未初始化)错误时,表示数组变量已被声明但尚未初始化。解决方法是在使用数组之前,通过指定数组的大小和类型来初始化数组,例如:`int[] arr = new int[5];` 或 `String[] strArr = new String[10];`。
115 2
|
3月前
|
存储 Java
什么是带有示例的 Java 中的交错数组?
什么是带有示例的 Java 中的交错数组?
64 9
|
3月前
|
Java
Java数组动态扩容和动态缩减
Java数组动态扩容和动态缩减
32 3