java实现稀疏数组压缩
package sparseArray;
public class SparseArray {
public static void main(String[] args) {
// TODO Auto-generated method stub
//创建一个原始的二维数组
// 0表示没有棋子,1表示黑子,2表示蓝子
int chessArr1[][] =new int[11][11];
chessArr1[1][2]=1;
chessArr1[2][3]=2;
//输出原始二维数组
System.out.println("原始的二维数组:");
for(int [] row:chessArr1)
{
for (int data:row)
{
System.out.printf("%d\t",data);
}
System.out.println();
}
//将二维数组转化成稀疏数组
//先遍历二维数组,获取非零元素的个数
int sum=0;
for(int i=0;i<chessArr1.length;i++)
{
for(int j=0;j<chessArr1[0].length;j++)
{
if(chessArr1[i][j]!=0)
{
sum++;
}
}
}
//创建对应的一个稀疏数组
int sparseArr2[][]=new int[sum+1][3];
//给稀疏数组赋值
sparseArr2[0][0]=11;
sparseArr2[0][1]=11;
sparseArr2[0][2]=sum;
int index=1;//稀疏数组的下标,记录是第几个非零数据
//遍历二维数组,将非零的值,存储到稀疏数组中
for(int i=0;i<chessArr1.length;i++)
{
for(int j=0;j<chessArr1[0].length;j++)
{
if(chessArr1[i][j]!=0)
{
sparseArr2[index][0]=i;
sparseArr2[index][1]=j;
sparseArr2[index][2]=chessArr1[i][j];
index++;
}
}
}
//输出稀疏数组的形式
System.out.println("得到的稀疏数组为如下形式:");
for(int i=0;i<sparseArr2.length;i++)
{
System.out.printf("%d\t%d\t%d\t",sparseArr2[i][0],sparseArr2[i][1],sparseArr2[i][2]);
System.out.println();
}
//将稀疏数组回复称原来的二维数组
//先读取稀疏数组的第一行
//赋值给对应数组就好了
int chessArr3[][]=new int[sparseArr2[0][0]][sparseArr2[0][1]];
//循环赋值
for(int i=1;i<sparseArr2.length;i++)
{
chessArr3[sparseArr2[i][0]][sparseArr2[i][1]]=sparseArr2[i][2];
}
//////////////////////////
System.out.println("输出恢复后的二维数组:");
for(int i=0;i<sparseArr2[0][0];i++)
{
for(int j=0;j<sparseArr2[0][1];j++)
{
System.out.printf("%d\t",chessArr3[i][j]);
}
System.out.println();
}
}
}
java实现稀疏数组压缩的更多相关文章
- Java的稀疏数组的简单代码实现
目录 Java的稀疏数组的简单代码实现 一.稀疏数组的基本概念 二.稀疏数组的Java代码实现思路 三.稀释数组的Java代码实现 四.结语 Java的稀疏数组的简单代码实现 一.稀疏数组的基本概念 ...
- java算法--稀疏数组
数据结构必要知识 线性结构 线性结构是最常用的数据结构,数据元素之间存在一对一的线性关系. 线性结构有两种不同的存储结构,即顺序存储结构和链式存储结构.顺序存储的线性表称为顺序表,顺序表中的存储元素是 ...
- 图解Java数据结构之稀疏数组
在编程中,算法的重要性不言而喻,没有算法的程序是没有灵魂的.可见算法的重要性. 然而,在学习算法之前我们需要掌握数据结构,数据结构是算法的基础. 我在大学的时候,学校里的数据结构是用C语言教的,因为对 ...
- 数据结构(1):稀疏数组使用java实现
主要是用于数组压缩,去除无效的数组内容: 原数组内容: 0 0 0 0 0 0 1 0 0 0 0 0 0 2 0 0 0 0 0 0 0 0 0 0 0 转换成 稀疏数组 5 5 2 1 1 1 2 ...
- 数据结构与算法之java语言实现(一):稀疏数组
一.概念&引入 什么是稀疏数组? 稀疏数组是面对一个二维数组中有众多重复元素的情况下,为了节省磁盘空间,将此二维数组转化为更加节省空间的一种数组,我们叫他稀疏数组. 只是听概念或许会看不明白, ...
- Java数据结构之稀疏数组(Sparse Array)
1.需求 编写的五子棋程序中,有存盘退出和续上盘的功能.因为该二维数组的很多值是默认值0,因此记录了很多没有意义的数据,为了压缩存储所以采用稀疏数组. 2.基本介绍 当一个数组中大部分元素为0,或者为 ...
- 【学习总结】java数据结构和算法-第三章-稀疏数组和队列
相关链接 [学习总结]尚硅谷2019java数据结构和算法 github:javaDSA 目录 稀疏数组 队列 稀疏数组 稀疏数组介绍 图示 应用实例 代码实现 SparseArray.java:与二 ...
- Java数组声明创建和使用以及多维数组、Arrays类、稀疏数组
目录 数组概述 数组声明创建 内存分析 java内存分析 堆 栈 方法区 三种初始化 静态初始化 动态初始化 数组的默认初始化 数组的四个基本特点 数组边界 小结: 数组使用 数组基础使用 For E ...
- Java数据结构和算法(2)之稀疏数组
1.定义 稀疏数组可以看做是普通二位数组的压缩,但是这里说的普通数组是值无效数据量远大于有效数据量的数组,关于稀疏数组的运用有五子棋盘,地图等.. *当一个数组中大部分元素为0,或者为同一个值的数组时 ...
随机推荐
- Oracle 别名
在Oracle数据库中,给表起别名时,直接"Tablename 别名"就可以,不需要AS. 在Oracle数据库中,数据表别名是不能加AS的,例如: SELECT a.USERNA ...
- 暑假集训 #3div2 C Sequence 数字找规律
C. Sequence (64 Mb, 1 sec / test)Integer sequences are very interesting mathematical objects. Let us ...
- TTTTTTTTTTT POJ 2749 修牛棚 2-Sat + 路径限制 变形
Building roads Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 7019 Accepted: 2387 De ...
- pycharm安装与永久激活
1.Pycham下载 https://www.jetbrains.com/pycharm/download/#section=windows 直接下载专业版 2.安装 这里就不必细说,直接next就O ...
- [CF1172E]Nauuo and ODT:Link-Cut Tree
分析 lxl大毒瘤. 感谢Ouuan等CNOIER提供了这么好的比赛. 这里只是把官方题解复述一遍,可以直接去看官方题解:点我. 考虑将问题转化为对于每个颜色,求出没有经过这个颜色的节点的路径有多少条 ...
- HTML和CSS 入门系列(二):文字、表单、表格、浮动、定位、框架布局、SEO
上一篇:HTML和CSS 入门系列(一):超链接.选择器.颜色.盒模式.DIV布局.图片 一.文字 1.1 属性 1.2 字体样式:font-family 1.3 字体大小:font-size 1.4 ...
- C++入门经典-例5.11-动态分配空间,堆与栈
1:在程序中定义一个变量,它的值会被放入内存中.如果没有申请动态分配,它的值将会被放在栈中.栈中的变量所属的内存大小是无法被改变的,它们的产生与消亡也与变量定义的位置和存储方式有关.堆是一种与栈相对应 ...
- C++入门经典-例3.24-找图书的位置
1:运行代码: // 3.24.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> usin ...
- 移动端 iphone手机在中文情况下不执行keyup事件
问题:移动端 在
- 全面解读php-正则表达式
一.正则表达式基础内容 注: 1.通用原子: \d : 数字. \D : 除了数字. \w : 数字,字母,下划线.\W : 除了数字,字母,下划线. \s : 空白符 . \S : 除了空白符 ...