欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 房产 > 家装 > JAVA算法数据结构第一节稀疏矩阵

JAVA算法数据结构第一节稀疏矩阵

2025/10/20 0:12:28 来源:https://blog.csdn.net/daibadetianshi/article/details/142307252  浏览:    关键词:JAVA算法数据结构第一节稀疏矩阵

一、稀疏矩阵介绍:

稀疏矩阵是一种特殊类型的矩阵,其中大部分元素都是零。在处理这类矩阵时,如果仍然使用标准的矩阵存储方式(即传统的二维数组),则会浪费大量的存储空间来保存零值。为了提高存储效率以及在某些情况下提高计算效率,人们发明了稀疏矩阵的概念及其相应的存储方法。

稀疏矩阵的特点

  • 高零值比例:矩阵中的零元素远多于非零元素。
  • 节省空间:只存储非零元素,减少不必要的内存占用。
  • 优化运算:在进行矩阵运算时,可以跳过与零相关的计算,从而加快计算速度。

二、稀疏矩阵代码实现:

1)原始二维代码: 

  //创建一个原始的二维数组9*9//0:表示没有棋子,1:表示黑子,2:表示白子int[][] ints = new int[9][9];ints[1][2]=1;ints[2][4]=2;//输出原始二维数组for (int[] row:ints){for (int data:row){System.out.print(data+"\t");}System.out.println();}

输出结果:

 

创建如图9*9的二维矩阵。

2)、将二维矩阵转化成稀疏矩阵:

  //创建对应稀疏矩阵int[][] xishu = new int[sum + 1][3];//给稀疏矩阵赋值xishu[0][0]=9;xishu[0][1]=9;xishu[0][2]=sum;//遍历二维数组,将非零值存放到xishu中int count=0;//用于记录是第几个非零数据for (int i=0;i<9;i++){for (int j=0;j<9;j++){if (ints[i][j]!=0){count++;xishu[count][0]=i;xishu[count][1]=j;xishu[count][2]=ints[i][j];}}}//输出稀疏数组的形式System.out.println("----------稀疏数组为---------");for (int i=0;i < xishu.length;i++){System.out.println(xishu[i][0]+"  "+xishu[i][1]+"  "+xishu[i][2]);}

输出结果:

 

3)、将稀疏矩阵转化为 二维矩阵:

   //读取稀疏数组第一行,根据第一行创建原始的二维数组int[][] huifus = new int[xishu[0][0]][xishu[0][1]];//读取稀疏数组后几行的数据并赋给原始二维数组即可//这里是要遍历稀疏矩阵的值而不是恢复矩阵for (int k=1;k< xishu.length;k++){huifus[xishu[k][0]][xishu[k][1]]=xishu[k][2];}System.out.println("---------恢复的二维矩阵-------");for (int[] row:huifus){for (int data:row){System.out.print(data+"\t");}System.out.println();}

输出结果:

 

三、完整代码:

//TIP 要<b>运行</b>代码,请按 <shortcut actionId="Run"/> 或
// 点击装订区域中的 <icon src="AllIcons.Actions.Execute"/> 图标。
public class Main {public static void main(String[] args) {//创建一个原始的二维数组9*9//0:表示没有棋子,1:表示黑子,2:表示白子int[][] ints = new int[9][9];ints[1][2]=1;ints[2][4]=2;//输出原始二维数组for (int[] row:ints){for (int data:row){System.out.print(data+"\t");}System.out.println();}
//将二维数组 转 稀疏数组的思想//1.先遍历二维数组 得到非零数据的个数int sum=0;for (int i=0;i<9;i++){for (int j=0;j<9;j++){if (ints[i][j]!=0){sum++;}}}//创建对应稀疏矩阵int[][] xishu = new int[sum + 1][3];//给稀疏矩阵赋值xishu[0][0]=9;xishu[0][1]=9;xishu[0][2]=sum;//遍历二维数组,将非零值存放到xishu中int count=0;//用于记录是第几个非零数据for (int i=0;i<9;i++){for (int j=0;j<9;j++){if (ints[i][j]!=0){count++;xishu[count][0]=i;xishu[count][1]=j;xishu[count][2]=ints[i][j];}}}//输出稀疏数组的形式System.out.println("----------稀疏数组为---------");for (int i=0;i < xishu.length;i++){System.out.println(xishu[i][0]+"  "+xishu[i][1]+"  "+xishu[i][2]);}//读取稀疏数组第一行,根据第一行创建原始的二维数组int[][] huifus = new int[xishu[0][0]][xishu[0][1]];//读取稀疏数组后几行的数据并赋给原始二维数组即可//这里是要遍历稀疏矩阵的值而不是恢复矩阵for (int k=1;k< xishu.length;k++){huifus[xishu[k][0]][xishu[k][1]]=xishu[k][2];}System.out.println("---------恢复的二维矩阵-------");for (int[] row:huifus){for (int data:row){System.out.print(data+"\t");}System.out.println();}}
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词