广告
返回顶部
首页 > 资讯 > 精选 >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://www.lsjlt.com/news/301927.html(转载时请注明来源链接)

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

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java怎么实现将二维数组转化为链式储存
    本篇内容介绍了“Java怎么实现将二维数组转化为链式储存”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!链式存储结构链式存储结构的线性表将采用...
    99+
    2023-06-22
  • 利用Java如何实现将二维数组转化为链式储存
    目录链式存储结构代码思路代码实现输出结果总结链式存储结构 链式存储结构的线性表将采用一组任意的存储单元存放线性表中的数据元素。由于不需要按顺序存储,链表在插入、删除数据元素时比顺序存...
    99+
    2022-11-12
  • 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
  • 利用java怎么将二维数组转换为json
    这篇文章将为大家详细讲解有关利用java怎么将二维数组转换为json,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。具体方法如下:package Tsets;public class erwe...
    99+
    2023-05-31
    java ava json
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作