稀疏数组(java)
2022/1/14 1:05:00
本文主要是介绍稀疏数组(java),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
稀疏数组
1、稀疏数组的代码实现
@Test public void test1() { int[][] num = new int[6][7]; int count = 0; //记录不同0的值 num[0][3] = 22; num[0][6] = 15; num[1][1] = 11; num[1][5] = 17; num[2][3] = -6; num[3][5] = 39; num[4][0] = 91; num[5][2] = 28; System.out.println("======================普通数组============================="); for (int[] i : num) { for (int j : i) { if (j != 0) { count++; } System.out.printf("%d\t",j); } System.out.println(""); } System.out.println("======================稀疏数组============================="); //转化为稀疏数组 int[][] sparseArray = new int[count+1][3]; int countNum1 = 1; //先放第一行的数据 sparseArray[0][0] = num.length; //获取行数 sparseArray[0][1] = num[0].length; //获取列数 sparseArray[0][2] = count; //8个不同值 //再放不为0的数 for (int i = 0;i<num.length;i++) { //行 for (int j = 0;j<num[0].length;j++) { //列 if (num[i][j] != 0) { sparseArray[countNum1][0] = i; //0号位为行号 sparseArray[countNum1][1] = j; //1号位为列号 sparseArray[countNum1][2] = num[i][j]; //改行好列号对应的值 countNum1++; } } } //遍历稀疏数组 for (int[] i : sparseArray) { for (int j : i) { System.out.printf("%d\t",j); } System.out.println(""); } System.out.println("=====================恢复后的普通数组=============================="); //将稀疏数组转回普通数组 int[][] num1 = new int[sparseArray[0][0]][sparseArray[0][1]]; for (int i = 1 ;i<sparseArray.length;i++) { for (int j = 0;j<sparseArray[0].length;j++) { num1[sparseArray[i][0]][sparseArray[i][1]] = sparseArray[i][j]; } } for (int[] i : num1) { for (int j : i) { System.out.printf("%d\t",j); } System.out.println(""); } }
这篇关于稀疏数组(java)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-11有哪些好用的家政团队管理工具?
- 2025-01-11营销人必看的GTM五个指标
- 2025-01-11办公软件在直播电商前期筹划中的应用与推荐
- 2025-01-11提升组织效率:上级管理者如何优化跨部门任务分配
- 2025-01-11酒店精细化运营背后的协同工具支持
- 2025-01-11跨境电商选品全攻略:工具使用、市场数据与选品策略
- 2025-01-11数据驱动酒店管理:在线工具的核心价值解析
- 2025-01-11cursor试用出现:Too many free trial accounts used on this machine 的解决方法
- 2025-01-11百万架构师第十四课:源码分析:Spring 源码分析:深入分析IOC那些鲜为人知的细节|JavaGuide
- 2025-01-11不得不了解的高效AI办公工具API