java数据结构基础:稀疏数组

 更新时间:2021年08月01日 10:41:58   作者:去吧猫头夜鹰  
今天带大家了解一下Java稀疏数组的相关知识,文中有非常详细的介绍及代码示例,对正在学习java的小伙伴们有很好地帮助,需要的朋友可以参考下

稀疏数组:

当一个二维数组中大部份的值为0,或者为同一值的时候,可以用稀疏数组来保存

实现思路:

记录二维数组有多少行多少列、多少个不同的值

把不同的值按照所在行列,记录在一个规模较小的数组中

举例:

11×11的二维数组:

对应的稀疏数组:

其中,第一行分别为,原二维数组总行数、总列数、不为0的数的个数

之后几行的每一列分别代表所在行、所在列、值

二维数组转稀疏数组实现思路:

1. 遍历二维数组,得到非0数据的个数

2. 创建对应的稀疏数组

3. 再次遍历二维数组,将非0的值存放到稀疏数组中

稀疏数组恢复二维数组实现思路:

1. 读取稀疏数组的第一行,根据第一行的数据,创建对应的二维数组

2. 读取稀疏数组后几行的数据,赋值给二维数组

代码实现:

//稀疏数组
public class SparseArray {
	public static void main(String[] args) {
		//创建一个原始的二维数组11 * 11
		int[][] chessArr = new int[11][11];
		chessArr[1][2] = 1;
		chessArr[2][3] = 2;
		chessArr[4][5] = 2;
		//输出原始的二维数组
		for (int[] row : chessArr) {
			for (int i : row) {
				System.out.printf("%d\t", i);
			}
			System.out.println();
		}

		//二维数组转稀疏数组
		//首先遍历二维数组,得到非0数据的个数
		int sum = 0;
		for (int i = 0; i < 11; i++) {
			for (int j = 0; j < 11; j++) {
				if (chessArr[i][j] != 0) {
					sum++;
				}
			}
		}
		//创建对应的稀疏数组
		int[][] sparseArr = new int[sum + 1][3];
		//对稀疏数组赋值
		sparseArr[0][0] = 11;
		sparseArr[0][1] = 11;
		sparseArr[0][2] = sum;
		//遍历二维数组,将非0的值存放到稀疏数组中
		int count = 0;	//用于记录是第几个非0数据
		for (int i = 0; i < 11; i++) {
			for (int j = 0; j < 11; j++) {
				if (chessArr[i][j] != 0) {
					count++;
					sparseArr[count][0] = i;
					sparseArr[count][1] = j;
					sparseArr[count][2] = chessArr[i][j];
				}
			}
		}
		//输出稀疏数组
		for(int i = 0; i < sparseArr.length; i++) {
			System.out.printf("%d\t%d\t%d\t", sparseArr[i][0], sparseArr[i][1], sparseArr[i][2]);
			System.out.println();
		}

		//稀疏数组恢复二维数组
		//首先读取稀疏数组的第一行,根据第一行的数据,创建原始的二维数组
		int newChessArr[][] = new int[sparseArr[0][0]][sparseArr[0][1]];
		//读取稀疏数组后几行的数据,赋值给二维数组
		for(int i = 1; i < sparseArr.length; i++) {
			newChessArr[sparseArr[i][0]][sparseArr[i][1]] = sparseArr[i][2];
		}
		//输出恢复后的二维数组
		//输出原始的二维数组
		for (int[] row : newChessArr) {
			for (int i : row) {
				System.out.printf("%d\t", i);
			}
			System.out.println();
		}
	}
}

输出结果:

0 0 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0 0
0 0 0 2 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 2 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 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
1 2 1
2 3 2
4 5 2
0 0 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0 0
0 0 0 2 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 2 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

相关文章

  • Java入门案列之猜拳小游戏

    Java入门案列之猜拳小游戏

    这篇文章主要为大家详细介绍了Java入门案列之猜拳小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-11-11
  • java string类方法深入解析

    java string类方法深入解析

    以下是对java中的string类方法进行了详细的分析介绍。需要的朋友可以过来参考下
    2013-08-08
  • java仿微信摇一摇实现播放音乐

    java仿微信摇一摇实现播放音乐

    这篇文章主要为大家详细介绍了java仿微信摇一摇实现播放音乐,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-06-06
  • 关于报错IDEA Terminated with exit code 1的解决方法

    关于报错IDEA Terminated with exit code 

    如果在IDEA构建项目时遇到下面这样的报错IDEA Terminated with exit code 1,那必然是Maven的设置参数重置了,导致下载错误引起的,本文给大家分享两种解决方法,需要的朋友可以参考下
    2022-08-08
  • Java中的同步与异步详细介绍

    Java中的同步与异步详细介绍

    这篇文章主要介绍了Java中的同步与异步详细介绍,具有一定参考价值,需要的朋友可以了解下。
    2017-11-11
  • spring boot linux启动方式详解

    spring boot linux启动方式详解

    这篇文章主要介绍了spring boot linux启动方式详解,分为为前台启动,后台启动和脚本启动的各种方式讲解,需要的朋友可以参考下
    2017-11-11
  • Java 数组迭代你会用吗

    Java 数组迭代你会用吗

    Java 数组是我们学习或工作中常用到的数据结构,我们会经常写数组迭代的代码,本文介绍三种数组迭代的方式,感兴趣的可以了解一下
    2021-09-09
  • java中Javers 比较两个类的差异

    java中Javers 比较两个类的差异

    本文主要介绍了Javers 比较两个类的差异,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • IDEA如何进行commit之后的代码回退

    IDEA如何进行commit之后的代码回退

    在 IntelliJ IDEA 中回退 Git 版本涉及查找提交记录、复制提交编号、重置 HEAD 并强行推送到远程仓库,本文提供详细步骤和注意事项,帮助用户安全地回退到旧版本
    2024-09-09
  • SpringMVC参数的传递之如何接收List数组类型的数据

    SpringMVC参数的传递之如何接收List数组类型的数据

    这篇文章主要介绍了SpringMVC参数的传递之如何接收List数组类型的数据,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10

最新评论