Java 稀疏数组

news2025/1/23 7:18:19

实际需求(应用场景)

稀疏数组基本介绍

 

上面表格的第一行中的6、7、8 表示左边的二维数组一共有 6 行 7 列,在数组中有 8 个不同的值,分别是22、15、 11、17、 -6、 39、 91、 28.

表格的其他行表示每个值所在的行列信息,如第二行表示 22 这个值在二维数组的第 0 行第 3 列

稀疏数组转换的思路分析

以上面的实际需求中的数组为例进行分析

二维数组 ——> 稀疏数组

  1. 遍历原始的二维数组,得到有效数据的个数 sum
  2. 根据 sum 创建稀疏数组 sparseArr (类型为:int[sum + 1][3])
  3. 在稀疏数组的第一行存入二维数组的行列总数和有效数据个数 sum
  4. 从稀疏数组的第二行开始,将二维数组的有效数据及其行列信息存入稀疏数组中

稀疏数组 ——> 二维数组

  1. 先读取稀疏数组的第一行数据,根据第一行的数据创建原始二维数组, 如 chessArr2 = int[11][11]
  2. 在读取稀疏数组后几行的数据,将读取到的有效数据赋值给原始的二维数组即可

稀疏数组的代码实现

 根据上述思路分析,代码实现如下:

class SparseArray {
    public static void main(String[] args) {
        // 创建一个原始的二维数组 11 * 11 大小
        int[][] chessArr1 = new int[11][11];
        // 0 表示没有棋子, 1 表示黑子, 2 表示蓝子
        chessArr1[1][2] = 1;
        chessArr1[2][3] = 2;
        // 输出原始的二维数组
        System.out.println("原始的二维数组:");
        for (int[] row : chessArr1) {
            for (int data : row) {
                System.out.printf(data + "\t");
            }
            System.out.println();
        }

        // 二维数组 ——> 稀疏数组
        // 1、遍历原始的二维数组,得到有效数据的个数 sum
        int sum = 0;
        for (int[] row : chessArr1) {
            for (int data : row) {
                if (data != 0) {
                    sum++;
                }
            }
        }
        System.out.println("sum 的值为:" + sum);

        // 2、根据 sum 创建稀疏数组 sparseArr (类型为:int[sum + 1][3])
        int[][] sparseArr = new int[sum + 1][3];

        // 3、在稀疏数组的第一行存入二维数组的行列总数和有效数据个数 sum
        sparseArr[0][0] = 11; // 存储原始二维数组 chessArr1 的行数
        sparseArr[0][1] = 11; // 存储原始二维数组 chessArr1 的列数
        sparseArr[0][2] = sum; // 存储原始二维数组 chessArr1 的有效数据个数

        // 4、从稀疏数组的第二行开始,遍历二维数组,将数组中的有效数据及其行列信息存入稀疏数组中
        int row = 1;
        // 遍历原始二维数组
        for (int i = 0; i < chessArr1.length; i++) {
            for (int j = 0; j < chessArr1[i].length; j++) {
                if (chessArr1[i][j] != 0) {
                    sparseArr[row][0] = i;
                    sparseArr[row][1] = j;
                    sparseArr[row][2] = chessArr1[i][j];
                    row++;
                }
            }
        }
        // 输出得到的稀疏数组
        System.out.println("得到的稀疏数组如下:");
        for (int[] i : sparseArr) {
            for (int j : i) {
                System.out.printf(j + "\t");
            }
            System.out.println();
        }

        // 稀疏数组 ——> 二维数组
        // 先读取稀疏数组的第一行数据,根据第一行的数据创建原始二维数组,如 chessArr2 = int[11][11]
        int[][] chessArr2 = new int[sparseArr[0][0]][sparseArr[0][1]];

        // 在读取稀疏数组后几行的数据,将读取到的有效数据赋值给原始的二维数组即可
        for (int i = 1; i < sparseArr.length; i++) {
            int row1 = sparseArr[i][0];
            int col1 = sparseArr[i][1];
            int val = sparseArr[i][2];
            chessArr2[row1][col1] = val;
        }
        System.out.println("还原后的二维数组:");
        for (int[] i : chessArr2) {
            for (int data : i) {
                System.out.printf(data + "\t");
            }
            System.out.println();
        }
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/785917.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

斯坦福开源FlashAttention,大模型速度翻倍

一年时间&#xff0c;斯坦福大学提出的新型 Attention 算法 ——FlashAttention 完成了进化。这次在算法、并行化和工作分区等方面都有了显著改进&#xff0c;对大模型的适用性也更强了。 近来&#xff0c;几种长上下文语言模型陆续问世&#xff0c;包括 GPT-4&#xff08;上下…

【C#性能】C# 语言中的数组迭代

一、说明 可迭代性&#xff0c;是数组等操作的根本&#xff1b;在C程序开发过程中&#xff0c;可迭代操作是非常普遍、非常广泛的&#xff0c;然而&#xff0c;对这种操作知道多少&#xff0c;又不知道多少&#xff0c;都将影响开发灵活性、开发的进度。因此&#xff0c;本文干…

vs2013 编译wxwidgets界面库

首先进入官网下载&#xff0c;本人再git上下载的基本都编译失败 https://www.wxwidgets.org/ 在网站里面找最新的就可以&#xff0c;下载之后放在一个目录&#xff0c;找到vs的目录 然后找到wx_vc12.sln&#xff0c;打开编译即可 Debug、Release编译出来的是静态库 DLL Deb…

P1149火柴棒等式题解

P1149[NOIP2008 提高组] 火柴棒等式 题目描述 给你 n n n 根火柴棍&#xff0c;你可以拼出多少个形如 A B C ABC ABC 的等式&#xff1f;等式中的 A A A、 B B B、 C C C 是用火柴棍拼出的整数&#xff08;若该数非零&#xff0c;则最高位不能是 0 0 0&#xff09;。用…

华南理工大学电信学院信号与系统实验1~4(杨俊美老师)

博客中仅放了题目&#xff0c;源码在下方链接&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1TpRAiNltybYWimETKHFKWA?pwd88ux 提取码&#xff1a;88ux --来自百度网盘超级会员V4的分享 有可能实验的序号可能编错码或者放错文件夹&#xff08;因为老师给的时候很多…

题目4 命令执行(保姆级教程)

url&#xff1a;http://192.168.154.253:84/ #打开http://XXX:81/&#xff0c;XXX为靶机的ip地址 审题 1、打开题目看到有一个提示&#xff0c;此题目需要通过利用命令执行漏洞执行Linux命令获取webshell&#xff0c;最后从根目录下key.php文件中获得flag 2、开始答题 第一步&…

【Kafka】消息队列Kafka基础

目录 消息队列简介消息队列的应用场景异步处理系统解耦流量削峰日志处理 消息队列的两种模式点对点模式发布订阅模式 Kafka简介及应用场景Kafka比较其他MQ的优势Kafka目录结构搭建Kafka集群编写Kafka一键启动/关闭脚本 Kafka基础操作创建topic生产消息到Kafka从Kafka消费消息使…

GB/T 25000.51解读——软件产品的可靠性怎么测?

GB/T 25000.51-2016《软件产品质量要求和测试细则》是申请软件检测CNAS认可一定会用到的一部国家标准。在前面的文章中&#xff0c;我们为大家整体介绍了GB/T 25000.51-2016《软件产品质量要求和测试细则》国家标准的结构和所涵盖的内容以及对软件产品的八大质量特性中的功能性…

re学习(24)攻防世界 Hello CTF(进制转换)

一.题目链接: https://adworld.xctf.org.cn/challenges/list 二.使用步骤 int __cdecl main(int argc, const char **argv, const char **envp) {int i; // ebxchar v4; // alint result; // eaxint v6; // [esp0h] [ebp-70h]int v7; // [esp0h] [ebp-70h]char Buffer[2]; //…

微信内测朋友圈可以置顶了

我是卢松松&#xff0c;点点上面的头像&#xff0c;欢迎关注我哦&#xff01; 微信现在算是垄断了聊天平台&#xff0c;每出个小功能都引起争议&#xff0c;这次朋友圈置顶就是个很好的例子&#xff1a;**微信内测朋友圈可以置顶了。已经上了大新闻、大热门!**如下图所示&…

10个流行的硬盘数据恢复软件:轻松恢复丢失的文件!

数据丢失对于个人和企业来说都是一场噩梦。无论是由于意外删除、硬件故障还是恶意攻击&#xff0c;丢失重要数据都可能导致重大挫折。 这就是硬盘数据恢复软件的用武之地&#xff01;使用正确的数据恢复工具&#xff0c;您可以检索有价值的文件并迅速回到正轨。我们将探索十种…

OpenCV系列__chapter2

这里写目录标题 1 图像加减乘除位运算1.1 加法 img cv2.add(img1, img2)1.2 减法 img cv2.subtract(img1, img2)1.3 乘法 img cv2.multiply(img1, img2)1.4 除法 img cv2.divide(img1, img2)1.5 位运算 2 图像增强2.1 线性变换2.2 非线性变换 3 图像几何变换3.1 裁剪、放大…

需求分析案例:餐厅排队叫号送券需求

本文介绍一个餐饮系统的排队送券需求&#xff0c;针对该需求进行边界划分和技术实现方案的过程。 1、需求提出 还是前文说的互联网餐饮系统&#xff0c;提供了餐厅排队叫号能力。 因为有些热门餐厅&#xff0c;吃饭的人太多了&#xff0c;就出现了很多排队时间长&#xff0c;…

SkyWalking链路追踪-技术文档首页

SkyWalking 文档中文版&#xff08;社区提供&#xff09; (skyapm.github.io)https://skyapm.github.io/document-cn-translation-of-skywalking/ SkyWalking-基本概念 SkyWalking链路追踪是一个用于分布式系统的性能监控工具&#xff0c;它帮助开发人员了解系统中各组件之间…

【如何训练一个中译英翻译器】LSTM机器翻译模型部署之ncnn(python)(四)

ncnn&#xff1a;https://github.com/Tencent/ncnn 1、.h5模型保存为TFSaveModel格式 import tensorflow as tf from keras.models import load_model# 加载Keras模型 model load_model(encoder_model.h5)# 转换为SavedModel类型 tf.saved_model.save(model, TFSaveModel)2、…

ssm 图书借阅管理系统 【纯干货分享,免费领源码06780】

大数据时代下&#xff0c;数据呈爆炸式地增长。为了迎合信息化时代的潮流和信息化安全的要求&#xff0c;利用互联网服务于其他行业&#xff0c;促进生产&#xff0c;已经是成为一种势不可挡的趋势。在图书馆的要求下&#xff0c;开发一款整体式结构的图书借阅管理系统&#xf…

5.44 综合案例2.0-矩阵键盘信息输入上传-OLED屏幕

综合案例2.0-矩阵键盘信息输入上传-OLED屏幕 案例说明1、应用场景2、M320矩阵引脚说明3、接线说明 搭建云平台环境1.添加设备2.创建设备类型3.功能定义&#xff08;创建物模型&#xff09; 代码1.更改MQTT信息 测试 案例说明 矩阵键盘输入信息显示在OLED显示屏上。按确定键可以…

Django 图书管理系统

一、功能及页面设计 二、页面展示 (1)首页 (2)注册 (3)登录 (4)普通用户登录 4.1查看图书页面 4.2查看图书详情页 4.3修改密码 (5)管理员登录 5.1添加图书 5.2添加图片 三、代码展示 因为代码太多不好一个个展示 所以需要源码的小伙伴可以找我要代码 感谢三连支持&#xff0…

云计算需求激增带来的基础设施挑战及解决方案

云计算的指数级增长迅速改变了我们消费和存储数字信息的方式。随着企业和个人越来越依赖基于云的服务和数据存储&#xff0c;对支持这些服务的强大且可扩展的基础设施的需求已达到前所未有的水平。 云计算需求的快速增长 我们的日常生活越来越多地被新技术所渗透。流媒体服务、…

剑指 Offer 29. 顺时针打印矩阵 / LeetCode 54. 螺旋矩阵(模拟)

题目&#xff1a; 链接&#xff1a;剑指 Offer 29. 顺时针打印矩阵&#xff1b;LeetCode 54. 螺旋矩阵 难度&#xff1a;中等 给你一个 m 行 n 列的矩阵 matrix &#xff0c;请按照 顺时针螺旋顺序 &#xff0c;返回矩阵中的所有元素。 示例 1&#xff1a; 输入&#xff1a…