Java如何实现二维数组与稀疏数组互转
发表于:2025-11-13 作者:千家信息网编辑
千家信息网最后更新 2025年11月13日,这篇文章主要介绍了Java如何实现二维数组与稀疏数组互转的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java如何实现二维数组与稀疏数组互转文章都会有所收获,下面我们一起
千家信息网最后更新 2025年11月13日Java如何实现二维数组与稀疏数组互转
这篇文章主要介绍了Java如何实现二维数组与稀疏数组互转的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java如何实现二维数组与稀疏数组互转文章都会有所收获,下面我们一起来看看吧。
二维数组
二维数组本质上是以数组作为数组元素的数组,即"数组的数组",类型说明符 数组名[常量表达式][常量表达式]。二维数组又称为矩阵,行列数相等的矩阵称为方阵。对称矩阵a[i][j] = a[j][i],对角矩阵:n阶方阵主对角线外都是零元素。
稀疏数组
1、稀疏算法的基本介绍
当一个数组中大部分元素为0,或者为同一个值的数组时,可以使用稀疏数组来保存该数组。从而减少计算机不必要的内存开销。
2、稀疏算法的处理方式
(1)数组中第一行记录原始数组中一共有几行几列,有多少个不同的值。
(2)把具有不同值的元素的行列及值记录在一个小规模的数组中,从而缩小程序的规模。
二维数组转稀疏数组的思路
遍历原始的二维数组,得到有效数据的个数sum,根据sum就可以创建稀疏数组sparseArr int[sum+1][3]
将二维数组的有效数据存入到稀疏数组
稀疏数组转原始的二维数组的思路:
先读取稀疏数组的第一行,根据第一行的数据,创建原始的二维数组,比如上面的chessArr2=int[11][11]
再读取稀疏数组后几行的数据,并赋给原始的二维数组即可
写一个二维数组:
//1.创建一个二维数组int chessArr1[][]=new int[11][11];//2.给二维数组赋值chessArr1[1][2]=1;chessArr1[2][3]=2;//3.双重for循环输出二维数组System.out.println("原始的二维数组:");for (int[] row : chessArr1) { for (int data : row) { System.out.printf("%d\t",data); } //每输出完一个一重数组换一行 System.out.println();}将二维数组换换位稀疏数组
//将二维数组转稀疏数组//1.先遍历二维数组,得到非0数据的个数,知道数据个数,就可以创建稀疏数组(知道了稀疏数组的行)int sum=0;for (int i = 0; i < 11; i++) { for (int j = 0; j < 11; j++) { if (chessArr1[i][j]!=0){ sum++; } }}System.out.println("有效值的个数为:"+sum);//2.创立对应的稀疏数组int sparseArr[][]=new int[sum+1][3];//3.给稀疏数组赋值sparseArr[0][0]=11;sparseArr[0][1]=11;sparseArr[0][2]=sum;//4.遍历二维数组,给稀疏数组int count=0;//用于记录是第几行for (int i = 0; i < 11; i++) { for (int j = 0; j < 11; j++) { if (chessArr1[i][j]!=0){ sparseArr[count+1][0]=i; sparseArr[count+1][1]=j; sparseArr[count+1][2]=chessArr1[i][j]; count++; } }}//5.输出稀疏数组//以下是两种遍历方式:/*for (int[] ints : sparseArr) { for (int anInt : ints) { System.out.printf("%d\t",anInt); } //把一个数组遍历完之后换一行 System.out.println();}*/System.out.println("得到稀疏数组为~~~~~");for (int i = 0; i < sparseArr.length; i++) { System.out.printf("%d\t%d\t%d\t\n",sparseArr[i][0],sparseArr[i][1],sparseArr[i][2]);}将稀疏数组还原为二维数组
//把稀疏数组还原为二维数组//1.创建二维数组int chessArr2[][]=new int[sparseArr[0][0]][sparseArr[0][1]];//2.给二维数组赋值for (int i = 1; i < sparseArr.length; i++) { chessArr2[sparseArr[i][0]][sparseArr[i][1]]=sparseArr[i][2];}//3.输出二维数组for (int[] row : chessArr2) { for (int data : row) { System.out.printf("%d\t",data); } System.out.println();}树越是向往高处的光亮,它的根就越要向下,向泥土向黑暗的深处。
关于"Java如何实现二维数组与稀疏数组互转"这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对"Java如何实现二维数组与稀疏数组互转"知识都有一定的了解,大家如果还想学习更多知识,欢迎关注行业资讯频道。
数组
二维
稀疏
原始
数据
一行
个数
元素
矩阵
输出
有效
知识
不同
内容
对角
常量
思路
方式
方阵
算法
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
新疆软件开发公司电话
欧博r18音乐服务器
网络技术毕业设计方向怎么写
软件开发维护专业术语
江苏pdu服务器电源价钱
迭代网络技术
公众号的数据库
网络安全自己有优势
湖北云三软件开发有限公司
软件开发最新技术有哪些
永恒轮回为什么无法连接服务器
人人通空间网络安全升级是什
数据库开放部分数据
塔科夫哪个服务器容易匹配
网络技术 本科
路由器网络技术新革新
网络安全策略三个重要组成部分
网络安全隐患排查工作
第一届和第二届网络安全主题
全世界对网络安全的行动
保障电子商务网络安全
苹果手机缴费软件连接服务器失败
漳州虚拟直播软件开发
计算机研究生网络安全
延边政务软件开发报价
电力电子软件开发工程师前景
关于数据库的备份方式
静安区品牌网络技术服务五星服务
军营网络安全宣传周群众大讨论
网络技术在侦查中的应用