返回顶部
首页 > 资讯 > 精选 >Java怎么实现将二维数组转化为链式储存
  • 286
分享到

Java怎么实现将二维数组转化为链式储存

2023-06-22 02:06:44 286人浏览 安东尼
摘要

本篇内容介绍了“Java怎么实现将二维数组转化为链式储存”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!链式存储结构链式存储结构的线性表将采用

本篇内容介绍了“Java怎么实现将二维数组转化为链式储存”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

链式存储结构

链式存储结构的线性表将采用一组任意的存储单元存放线性表中的数据元素。由于不需要按顺序存储,链表在插入、删除数据元素时比顺序存储要快,但是在查找一个节点时则要比顺序存储要慢。

使用链式存储可以克服顺序线性表需要预先知道数据大小的缺点,链表结构可以充分利用内存空间,实现灵活的内存动态管理。但是链式存储失去了数组随机存取的特点,同时增加了节点的指针域,空间开销较大。

下图就是最简单最一般的单向链表:

Java怎么实现将二维数组转化为链式储存

代码思路

将二维数组压缩成链式存储大体思路与数组压缩成稀疏数组相似
这里我将链表的头节点储存二维数组的总行数、列数和有效值个
数 头结点之后的每个结点存储有效值的下标和值 转化思路如下图所示

Java怎么实现将二维数组转化为链式储存

代码实现

创建模拟结点的类 提供构造方法和toString

public class Singlenode {        public int row;    public int colunm;    public int num;        public SingleNode next;    public SingleNode(int row, int colunm, int num) {        this.row = row;        this.colunm = colunm;        this.num = num;    }    @Override    public String toString() {        return "SingleNode{" + "row=" + row + ", colunm=" + colunm + ", num=" + num + '}';    }}

创建模拟链表类 提供添加结点、遍历链表和还原数组等方法

public class SingleLinkList {    //头节点    private SingleNode headSingleNode;//通过构造行数初始化头节点    public SingleLinkList(SingleNode headSingleNode) {        this.headSingleNode = headSingleNode;    }        public void add(SingleNode SingleNode){        SingleNode temp = headSingleNode;        while(true){            if (temp.next == null) {                //如果这个结点的next域为空就跳出while循环                break;            }            //将下一个结点赋值给temp            temp = temp.next;        }        temp.next= SingleNode;    }        public void show(){        if (headSingleNode.next == null) {            System.out.println("当前链表为空");            return;        }        SingleNode temp = headSingleNode;        while (true){            if (temp.next == null){                break;            }            temp = temp.next;            System.out.println(temp);        }    }        public int[][] backToArray(){        SingleNode temp = headSingleNode;        //头结点中存储着原数组的行数和列数        //通过这两个值创建二维数组        int[][] array = new int[headSingleNode.row][headSingleNode.colunm];        while (true){            if (temp.next == null){                break;            }            temp = temp.next;            //每遍历一个结点就还原一个数据            array[temp.row][temp.colunm] = temp.num;        }        return array;    }}
public class ArrayToLink {    public static void main(String[] args) {        int[][] array = new int[4][5];        //初始化二维数组        array[0][2] = 1;        array[1][1] = 2;        array[2][3] = 3;        System.out.println("========普通数组========");        //遍历二维数组        int count = 0;        for (int i = 0; i < array.length; i++) {            for (int j = 0; j < array[i].length; j++) {                if (array[i][j]!=0){                    count++;                }                System.out.print(array[i][j] + " ");            }            System.out.println();        }        //将数组转化成链式存储        SingleLinkList list = new SingleLinkList(new SingleNode(array.length,array[0].length,count));        for (int i = 0; i < array.length; i++) {            for (int j = 0; j < array[i].length; j++) {                if (array[i][j] != 0){                //当数字不为0时视为有效值就创建一个结点并添加到链表尾部                    list.add(new SingleNode(i,j,array[i][j]));                }            }        }        System.out.println("========转化后的链表========");        //遍历单向链表        list.show();        int[][] returnArray = list.backToArray();        //遍历还原后的二维数组        System.out.println("========还原后的数组========");        for (int i = 0; i < returnArray.length; i++) {            for (int j = 0; j < returnArray[i].length; j++) {                System.out.print(returnArray[i][j] + " ");            }            System.out.println();        }    }}

输出结果

Java怎么实现将二维数组转化为链式储存

“Java怎么实现将二维数组转化为链式储存”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: Java怎么实现将二维数组转化为链式储存

本文链接: https://lsjlt.com/news/301927.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Java怎么实现将二维数组转化为链式储存
    本篇内容介绍了“Java怎么实现将二维数组转化为链式储存”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!链式存储结构链式存储结构的线性表将采用...
    99+
    2023-06-22
  • 利用Java如何实现将二维数组转化为链式储存
    目录链式存储结构代码思路代码实现输出结果总结链式存储结构 链式存储结构的线性表将采用一组任意的存储单元存放线性表中的数据元素。由于不需要按顺序存储,链表在插入、删除数据元素时比顺序存...
    99+
    2024-04-02
  • java怎么将二维数组转化为稀疏数组
    本篇内容主要讲解“java怎么将二维数组转化为稀疏数组”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“java怎么将二维数组转化为稀疏数组”吧!特点它可以压缩数据,减少内存空间的使用。过程记录数组...
    99+
    2023-06-30
  • vue怎么将二维数组转化为一维数组
    本篇内容主要讲解“vue怎么将二维数组转化为一维数组”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue怎么将二维数组转化为一维数组”吧!将二维数组转化为一维数组需求数组嵌套数据,导致循环不方便...
    99+
    2023-06-30
  • 利用java 怎么将Map转化为二维数组
    利用java 怎么将Map转化为二维数组?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。实例代码:import java.util.HashMap; import java.ut...
    99+
    2023-05-31
    java map ava
  • php怎么将二维数组转为一维数组
    本教程操作环境:windows7系统、PHP7.1版、DELL G3电脑二维数组转一维数组总结 例如将如下二位数组转以为以为一维数组$records = [ [ 'id' => 2135,...
    99+
    2014-10-22
    php 数组 二维数组 一维数组
  • php怎么将一维数组转为二维数组
    本教程操作环境:windows7系统、PHP7.1版、DELL G3电脑在php中,可以利用array_chunk()函数来将一维数组转为二维数组。示例:<php header("Content-type:text/html...
    99+
    2021-07-28
    php 数组 一维数组转二维数组
  • php怎么将二维数组转为一维
    在开发PHP程序时,我们经常需要在代码中使用数组数据,其中使用的二维数组也很常见。但是,在某些情况下,我们需要将二维数组转换为一维数组。这在编写PHP应用程序时非常有用。以下是如何将PHP二维数组转换为一维数组的详细步骤。一、使用forea...
    99+
    2023-05-14
  • vue如何将二维数组转化为一维数组
    目录将二维数组转化为一维数组需求具体实现将多维数组转一维数组6种方法ES6 flat方法递归reduce +concat + 递归join+splittoString+splitev...
    99+
    2024-04-02
  • python二维数组怎么转化为一维数组
    要将一个二维数组转化为一维数组,可以使用列表推导式(list comprehension)或者使用numpy库中的flatten()...
    99+
    2023-09-27
    python
  • 利用java怎么将二维数组转换为json
    这篇文章将为大家详细讲解有关利用java怎么将二维数组转换为json,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。具体方法如下:package Tsets;public class erwe...
    99+
    2023-05-31
    java ava json
  • php怎样将一维数组转为二维数组
    php怎样将一维数组转为二维数组,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。在php中,可以利用array_chunk()函数来将一维数组转为二维数组,该函数的作用就是分割数...
    99+
    2023-06-29
  • php怎么将二维数组转为字符串
    转换步骤:1、使用array_reduce()函数将二维数组转为一维数组,语法“array_reduce(二维数组, 'array_merge', array())”,会返回一个包含二维数组中所有元素值的一维数组;2、使用i...
    99+
    2022-08-17
    php php数组 php字符串
  • php怎么将一维数组转为三维数组
    对于PHP程序员来说,数组是一个非常重要的概念,也是日常工作中必不可少的数据类型。在PHP中,数组可以分为一维数组、二维数组和多维数组等多种形式。其中,一维数组是最基本也是最常见的一种数组类型。在一些特殊的场合下,我们需要将一维数组转化为三...
    99+
    2023-05-14
  • php怎么实现二维数组旋转
    本文操作环境:Windows7系统,PHP7.4版,Dell G3电脑。php怎么实现二维数组旋转?PHP二维数组矩形转置实例<php //二维数组转置 //定义一个二维数组 $arr =array(array...
    99+
    2014-09-26
    php
  • python怎么实现二维数组转置
    要实现二维数组的转置,可以使用嵌套的循环来交换数组中的元素位置。下面是一个示例:```pythondef transpose(mat...
    99+
    2023-08-18
    python
  • php怎么实现自动将链接转换成二维码
    本文小编为大家详细介绍“php怎么实现自动将链接转换成二维码”,内容详细,步骤清晰,细节处理妥当,希望这篇“php怎么实现自动将链接转换成二维码”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、生成二维码在PHP...
    99+
    2023-07-05
  • php多维数组怎么转化为一维数组
    可以使用array_merge_recursive()函数将多维数组转化为一维数组。示例代码如下:```php$array = ar...
    99+
    2023-10-11
    php
  • JS一维数组转化为三维数组的实现示例
    今天在CSDN上问答区看到一个提问的小伙伴,是想要将一维数组转化为三位数组的需求,正好不是很忙,乐于助人的我立马给这位同学安排上,当然也没有顾及那么多去看资料什么的,就直接按照自己的...
    99+
    2024-04-02
  • ES6怎么将Set转化为数组
    本文小编为大家详细介绍“ES6怎么将Set转化为数组”,内容详细,步骤清晰,细节处理妥当,希望这篇“ES6怎么将Set转化为数组”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Set 是 ES6 中新增的一种集合类...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作