稀疏矩阵的压缩与还原

稀疏数组中元素个数很少或者有大量的重复值,如果直接保存保存,会浪费很多空间,这时,就可以考虑对数组进行压缩存储。

先定义一个稀疏数组

//创建一个二维数组 11 * 11
int[][] array1 = new int[11][11];
//给一些元素赋值
array1[1][2] = 1;
array1[2][3] = 2;
array1[4][4] = 1;
array1[8][5] = 2;

打印初始数组

//输出原始数组
System.out.println("输出原始数组");
for (int[] arr : array1) {
System.out.println(Arrays.toString(arr));
}

压缩稀疏数组

在压缩数组时,我们可以用稀疏数组的第一行来存储元素数组的大小及原始数组的有效个数。下表为稀疏数组存储的内容,第一行为原始数组的行、列、元素个数。其余行为有效值信息,包括行坐标、列坐标以及有效值。

0 1 2
0 原始数组行数 原始数组列数 有效值个数
1 行坐标 列坐标 有效值
2 行坐标 列坐标 有效值
...... 行坐标 列坐标 有效值

通过原始数组获取有效值个数

//获取有效值个数
int sum = 0;
for (int i = 0; i < array1.length; i++) {
for (int j = 0; j < array1[i].length; j++) {
if (array1[i][j] != 0)
sum++;
}
}
System.out.println("有效个数为:" + sum);



根据有效值的个数创建稀疏数组,稀疏数组的行数为有效值个数加1,列数固定为3.

int[][] array2 = new int[sum + 1][3];
array2[0][0] = 11;//原始数组行数
array2[0][1] = 11;//原始数组列数
array2[0][2] = sum;//有效值个数

接下来就可以保存原始数组的有效值信息了。先利用一个计数器记录有效值个数。

//遍历二维数组,将非零的值,存放稀疏数组中
int count = 0;//计数作用
for (int i = 0; i < array1.length; i++) {
for (int j = 0; j < array1[i].length; j++) {
if (array1[i][j] != 0) {
count++;//稀疏数组从第二行开始存有效值信息
array2[count][0] = i;//有效值的行坐标
array2[count][1] = j;//有效值的列坐标
array2[count][2] = array1[i][j];//有效值
}
}
}

输出稀疏矩阵

for (int i = 0; i < array2.length; i++) {
System.out.println(array2[i][0] + "\t" + array2[i][1] + "\t" + array2[i][2]);
}

通过稀疏数组还原原始数组

由于稀疏数组的第一行是保存的元素数组的大小,因此我们可以用其来创建一个元素数组的大小。

int[][] array3 = new int[array2[0][0]][array2[0][1]];//array2[0][0]存储的为原始数组的行数,array2[0][1]存储的为原始数组的列数

从稀疏数组下标为1开始遍历,因为1开始才是有效值的信息。如array2[1][0]就是第一个有效值的行坐标,array2[1][1]就是第一个有效值的列坐标,array2[1][2]就是第一个有效值。

for (int i = 1; i < array2.length; i++) {
array3[array2[i][0]][array2[i][1]] = array2[i][2];
}

最后输出还原后的数组。

//输出还原数组
System.out.println("输出还原数组");
for (int[] arr : array3) {
System.out.println(Arrays.toString(arr));
}

完整代码

package com.jiang.array;

import java.util.Arrays;

/**
* @author HaiJaine
**/
public class ArrayDemo08 {
public static void main(String[] args) {
//创建一个二维数组 11 * 11
int[][] array1 = new int[11][11];
//给一些元素赋值
array1[1][2] = 1;
array1[2][3] = 2;
array1[4][4] = 1;
array1[8][5] = 2;
//输出原始数组
System.out.println("输出原始数组");
for (int[] arr : array1) {
System.out.println(Arrays.toString(arr));
}
System.out.println("=================================");
//转换为稀疏数组保存
//获取有效值个数
int sum = 0;
for (int i = 0; i < array1.length; i++) {
for (int j = 0; j < array1[i].length; j++) {
if (array1[i][j] != 0)
sum++;
}
}
System.out.println("有效个数为:" + sum); //创建一个稀疏数组,第一个行为原始数组的行、列、有效值个数,其余行分别保存元素所在的行、列、元素值
int[][] array2 = new int[sum + 1][3];
array2[0][0] = 11;//原始数组行数
array2[0][1] = 11;//原始数组列数
array2[0][2] = sum;//有效值个数 //遍历二维数组,将非零的值,存放稀疏数组中
int count = 0;//计数作用
for (int i = 0; i < array1.length; i++) {
for (int j = 0; j < array1[i].length; j++) {
if (array1[i][j] != 0) {
count++;//稀疏数组从第二行开始存有效值信息
array2[count][0] = i;//有效值的行坐标
array2[count][1] = j;//有效值的列坐标
array2[count][2] = array1[i][j];//有效值
}
}
}
System.out.println("稀疏数组");
for (int i = 0; i < array2.length; i++) {
System.out.println(array2[i][0] + "\t" + array2[i][1] + "\t" + array2[i][2]);
}
System.out.println("=================================");
System.out.println("稀疏矩阵还原");
//1、读取稀疏数组
int[][] array3 = new int[array2[0][0]][array2[0][1]];//array2[0][0]存储的为原始数组的行数,array2[0][1]存储的为原始数组的列数
//2、给其中的元素还原它的值
for (int i = 1; i < array2.length; i++) {
array3[array2[i][0]][array2[i][1]] = array2[i][2];
}
//输出还原数组
System.out.println("输出还原数组");
for (int[] arr : array3) {
System.out.println(Arrays.toString(arr));
}
}
}

使用Java对稀疏数组的压缩与还原的更多相关文章

  1. Java的稀疏数组的简单代码实现

    目录 Java的稀疏数组的简单代码实现 一.稀疏数组的基本概念 二.稀疏数组的Java代码实现思路 三.稀释数组的Java代码实现 四.结语 Java的稀疏数组的简单代码实现 一.稀疏数组的基本概念 ...

  2. java实现稀疏数组压缩

    package sparseArray; public class SparseArray { public static void main(String[] args) { // TODO Aut ...

  3. java算法--稀疏数组

    数据结构必要知识 线性结构 线性结构是最常用的数据结构,数据元素之间存在一对一的线性关系. 线性结构有两种不同的存储结构,即顺序存储结构和链式存储结构.顺序存储的线性表称为顺序表,顺序表中的存储元素是 ...

  4. 图解Java数据结构之稀疏数组

    在编程中,算法的重要性不言而喻,没有算法的程序是没有灵魂的.可见算法的重要性. 然而,在学习算法之前我们需要掌握数据结构,数据结构是算法的基础. 我在大学的时候,学校里的数据结构是用C语言教的,因为对 ...

  5. Java.稀疏数组

    package array; public class demo06 { public static void main(String[] args) { //创建一个二维数组 11*11 int[] ...

  6. java数组---稀疏数组与数组之间的相互转化

    public static void main(String[] args) { int[][]array1=new int[11][11]; array1[1][2]=1; array1[2][3] ...

  7. Java方法和数组

    方法 什么是方法 Java方法是语句的集合,它们在一起执行一个功能. 方法是解决一类问题的步骤的有序组合 方法包含于类或对象中 方法在程序中被创建,在其他地方被引用 设计方法的原则:方法的本意是功能块 ...

  8. golang数据结构之稀疏数组

    掌握知识: 数组的初始化和赋值 结构体的初始化和赋值 字符串和整型之间的转换以及其它的一些操作 类型断言 读取文件 写入文件 对稀疏数组进行压缩 package main import ( " ...

  9. 数据结构(1):稀疏数组使用java实现

    主要是用于数组压缩,去除无效的数组内容: 原数组内容: 0 0 0 0 0 0 1 0 0 0 0 0 0 2 0 0 0 0 0 0 0 0 0 0 0 转换成 稀疏数组 5 5 2 1 1 1 2 ...

  10. 数据结构与算法之java语言实现(一):稀疏数组

    一.概念&引入 什么是稀疏数组? 稀疏数组是面对一个二维数组中有众多重复元素的情况下,为了节省磁盘空间,将此二维数组转化为更加节省空间的一种数组,我们叫他稀疏数组. 只是听概念或许会看不明白, ...

随机推荐

  1. 椭圆曲线密码学(ECC)加解密,附带python代码

    想起来很久没写博客了,刚好今天要写实验报告,随便把之前的也完成吧 1.椭圆曲线概念 椭圆曲线在经过化解后,可以用这条式子表达:E:y²=x³+ax+b 其背后的密码学原理,是基于椭圆曲线离散对数问题, ...

  2. 开源一站式敏捷测试管理&极简项目管理 itest(爱测试) 6.6.0 发布 ,新增拖拽生成接口测试断言

    itest 简介 itest 开源敏捷测试管理,testOps 践行者,极简的任务管理,测试管理,缺陷管理,测试环境管理,接口测试5合1,又有丰富的统计分析.可按测试包分配测试用例执行,也可建测试迭代 ...

  3. 代码审计——基础(JAVAEE)

    JAVAEE 目录 JAVAEE 常见框架 Struct2(控制层) Hibernate(持久层(与数据库交互)(不用再写简单的sql语句,但是需要一些列复杂的配置文件))(全ORM模型) Sprin ...

  4. 剑指Offer-60.把二叉树打印成多行(C++/Java)

    题目: 从上到下按层打印二叉树,同一层结点从左至右输出.每一层输出一行. 分析: 层次打印二叉树,在打印二叉树结点的同时,保存好结点的左右孩子,不断的重复打印,直到需要打印的数组为空即可. 程序: C ...

  5. 不好分类的好题Record

    这里装的是一些不太好分类的. problem 1 给你 \(n\) 个序列,第 \(i\) 个序列的长度为 \(m_i\),要求在每个序列中选择一个数,每种选法的代价为选择的 \(n\) 个数之和,请 ...

  6. 编程语言界的丐帮 C#.NET FRAMEWORK 4.6 EF 连接MYSQL

    1.nuget 引用 EntityFramework .和 MySql.Data.EntityFramework. EntityFramework  版本:6.4.4,MySql.Data.Entit ...

  7. Grafana 开源了一款 eBPF 采集器 Beyla

    eBPF 的发展如火如荼,在可观测性领域大放异彩,Grafana 近期也发布了一款 eBPF 采集器,可以采集服务的 RED 指标,本文做一个尝鲜介绍,让读者有个大概了解. eBPF 基础介绍可以参考 ...

  8. __proto__和[[Prototype]]的区别

    __proto__和[[Prototype]]的区别 先看下面这一段代码: const obj1 = Object.create(null); // very plain object obj1.__ ...

  9. Flink状态(二)

    Flink提供了不同的状态存储方式,并说明了状态如何存和存储在哪里. 状态可以被存储在Jvm的堆和堆外.根据状态存储方式的不同,Flink也能代替应用管理状态,意思是Flink能够进行内存管理(有必要 ...

  10. Linux 修改 hostname

    背景 之前安装Linux系统的时候,没有明确指定.现在因为在做某些实验的时候,为了更好地区分我所登录的每一台服务器. 于是有了此文. 做法 首先修改/etc/hostname,修改为自己想要的名字xx ...