当前位置: 首页 > news >正文

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();}}
}


http://www.mrgr.cn/news/28328.html

相关文章:

  • HTTP 安全头配置:如何配置 HTTP 安全头来保护应用
  • git撤销、回退某个commit的修改
  • 【数据结构】什么是链栈?
  • ChatGPT登录失败的潜在原因分析
  • 去地面算法——depth_clustering算法调试(1)
  • Vue3 -- 环境变量的配置【项目集成3】
  • Python数据分析-世界上最富有的1000人
  • re题(21)BUUCTF—findit
  • 除了C# 、C++,C++ cli 、还有一个Java版的 db
  • 面试官问:请描述一次你成功解决问题的经历?
  • c++ #include <cmath>介绍
  • centos更改静态ip
  • 面试官问:你在团队中的角色是什么?
  • Vue3+Element Plus:使用el-dialog,对话框可拖动,且对话框弹出时仍然能够在背景页(对话框外部的页面部分)上进行滚动以及输入框输入信息
  • 一个有趣的“苦无”测试探针笔的设计
  • Python Pyvis库创建交互式网络图 高级功能详解
  • 【Python基础】Python 装饰器(优雅的代码增强工具)
  • STM32之FMC—扩展外部 SDRAM
  • SpringBoot 消息队列RabbitMQ 消息可靠性 数据持久化 与 LazyQueue
  • Java读取寄存器数据的方法
  • 53. 最大子数组和
  • 微信视频号导出视频软件
  • Python 课程12-Python 自动化应用
  • 【思博伦】史上最详细思博伦测试仪使用教程精讲(三)!图解超赞超详细!!!
  • 二叉树OJ题——另一棵树的子树
  • 【Linux篇】TCP/IP协议(笔记)