返回顶部
首页 > 资讯 > 精选 >Java如何实现双向链表
  • 155
分享到

Java如何实现双向链表

2023-06-30 16:06:30 155人浏览 薄情痞子
摘要

本篇内容介绍了“Java如何实现双向链表”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、双向链表1 双向链表的每个节点组成包含节点数据,上

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

1、双向链表

1 双向链表的每个节点组成包含节点数据,上一个节点(pre),下一个节点(next)

2 双向链表节点结构

class node {//节点数据data        int data;        Node pre;        Node next;        public Node(int data) {            this.data = data;        }        public Node() {            super();        }            }

2、双向链表的增删改查(crud)

1 双向链表的增删改查

public class DoubleLinkedList {    private Node first;    private Node current;    private static class Node {        int data;        Node pre;        Node next;        public Node(int data) {            super();            this.data = data;        }        public Node() {            super();        }            }    public DoubleLinkedList() {        super();    }        public void add(int val) {        // 如果是头结点        if (first == null) {            Node node = new Node(val);            first = node;            first.pre = null;            first.next = null;            current = first;        } else {            Node node = new Node(val);            current.next = node;            node.pre = current;            current = node;        }    }        public void del(int val) {        if (first == null) {            System.out.println("双向链表为空,无法进行删除操作!");        } else {                        Node node = first;            while(true) {                // 首节点的删除可能                if (node.data == val) {                    //如果只有一个节点                    if(node.next==null) {                        node=null;                        first=null;                        System.out.println("删除所有的"+val+"成功");                        return;                    }else {                        node = node.next;                        node.pre.next=null;                        node.pre=null;                        first=node;                        //删除后重新循环判断首节点是否值相等                        continue;                    }                                                    } else {                                        while (node.next != null) {                        if (node.data == val) {                            node.pre.next = node.next;                            node.next.pre = node.pre;                            Node tempNode = node.pre;                            node.pre=null;                            node.next=null;                            node = tempNode;                        }                        node = node.next;                    }                    // 末节点删除可能                    if (node.data == val) {                        node.pre.next=null;                        node.pre=null;                    }                    System.out.println("删除所有的"+val+"成功");                    //末节点判断完成后,结束循环                    return;                }            }        }    }        public void traverse() {        if(first==null) {            System.out.println("双向链表为空");        }else {            Node node = first;            //循环遍历到倒数第二个节点截止            while(node.next!=null) {                System.out.print(node.data+" ");                node=node.next;            }            //遍历最后一个节点            System.out.print(node.data);        }    }        public void insert(int value,int insert) {                if(first==null) {            System.out.println("双向链表为空,无法插入");        }else {            Node node = first;            //循环遍历到倒数第二个节点截止            while(node.next!=null) {                if(node.data==value) {                    Node insertNode = new Node(insert);                    node.next.pre = insertNode;                    insertNode.next = node.next;                    node.next = insertNode;                    insertNode.pre = node;                }                node=node.next;            }            //最后一个节点后插入            if(node.data == value) {                Node insertNode = new Node(insert);                node.next = insertNode;                insertNode.pre = node;            }            System.out.println();            System.out.println("插入操作完成");                    }    }        public void revise(int val,int revised) {        if(first==null) {            System.out.println("双向链表为空,无法修改");        }else {            Node node = first;            while (node.next!=null) {                if(node.data == val) {                    node.data = revised;                }                node=node.next;            }            if(node.data == val) {}            node.data = revised;        }        System.out.println("修改操作完成");    }        public void contain(int val) {        if(first==null) {            System.out.println("链表为空,无法查找");        }else {            Node node = first;            while(node!=null) {                if(node.data==val) {                    System.out.println("该链表中包含"+val+"的值");                    return;                }else {                    node=node.next;                }            }            System.out.println("该链表不包含"+val);        }    }}

2 测试类(main入口函数)

public class Main {    public static void main(String[] args) {        DoubleLinkedList list = new DoubleLinkedList();        list.add(1);        list.add(1);        list.add(2);        list.insert(1, 3);        list.add(2);        list.add(3);        list.traverse();        System.out.println();        list.del(1);            list.traverse();        list.add(4);        System.out.println();        list.traverse();        System.out.println();        list.contain(4);                list.contain(3);        list.contain(0);    }}

3、一些缺点待修改

1)、循环结束是到倒数第二个节点截止的,要考虑多种不同的情况,头节点删除,尾结点删除等,导致删除函数复杂了很多
2)、在contain函数中有修改到循环到最后一个节点
3)、后续对删除函数修改有空再操作(待完成)

“Java如何实现双向链表”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: Java如何实现双向链表

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

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

猜你喜欢
  • Java如何实现双向链表
    本篇内容介绍了“Java如何实现双向链表”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、双向链表1 双向链表的每个节点组成包含节点数据,上...
    99+
    2023-06-30
  • Java实现双向链表
    本文实例为大家分享了Java实现双向链表的具体代码,供大家参考,具体内容如下 1、双向链表 1.1 双向链表的每个节点组成包含节点数据,上一个节点(pre),下一个节点(next) ...
    99+
    2024-04-02
  • Java如何实现双向链表功能
    双向链表实现 双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继...
    99+
    2024-04-02
  • C语言如何实现双向链表和双向循环链表
    本文小编为大家详细介绍“C语言如何实现双向链表和双向循环链表”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言如何实现双向链表和双向循环链表”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。双向链表和双向循环链表...
    99+
    2023-06-16
  • java模拟实现双向链表
    双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点 下图是双...
    99+
    2024-04-02
  • java代码实现双向链表
    本文实例为大家分享了双向链表java实现代码,供大家参考,具体内容如下 一、双向链表简介 1、单链表的缺陷 单链表只能从头结点开始访问链表中的数据元素,如果需要逆序访问单链表中的数据...
    99+
    2024-04-02
  • 基于Java实现双向链表
    本文实例为大家分享了Java实现双向链表的具体代码,供大家参考,具体内容如下 双向链表与单链表的对比: 1、单向链表查找只能是一个方向,双向链表可以向前或者向后查找2、单向链表不能自...
    99+
    2024-04-02
  • java双向链表怎么实现
    Java中的双向链表可以通过定义一个Node类来实现,该类包含一个值和两个指针,分别指向前一个节点和后一个节点。具体实现如下: pu...
    99+
    2023-10-22
    java
  • Java如何实现无头双向链表操作
    这篇文章主要介绍了Java如何实现无头双向链表操作,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体内容如下无头双向链表的结构:代码分析节点结构class Node...
    99+
    2023-06-28
  • java 中的双向链表是如何实现的
    这篇文章将为大家详细讲解有关java 中的双向链表是如何实现的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。java 实现双向链表实例详解 双向链表是一个基本的数据结构,在Java...
    99+
    2023-05-31
    java 双向链 ava
  • 利用Java如何实现一个双向链表
    利用Java如何实现一个双向链表?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Java中双向链表详解及实例写在前面:  双向链表是一种对称结构,它克服了单链表上...
    99+
    2023-05-31
    java 双向链表 ava
  • java如何实现双向链表的增删改
    这篇文章主要介绍“java如何实现双向链表的增删改”,在日常操作中,相信很多人在java如何实现双向链表的增删改问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java如何实现双向链表的增删改”的疑惑有所帮助!...
    99+
    2023-06-30
  • JAVA中怎么实现链表和双向链表
    这篇文章给大家介绍JAVA中怎么实现链表和双向链表,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。JAVA基础:语言中链表和双向链表的实现(转)[@more@]链表是一种重要的数据结构,在程序设计中占有很重要的地位。C语...
    99+
    2023-06-03
  • Python实现双向链表
    之前写的单向链表和环形链表都只是单向的,只能单向遍历,不能根据后面的节点获取前面的节点,除非进行反转操作。 双向链表每个节点都有两个指针,这两个指针分别指向前后两个节点,这样就可以从...
    99+
    2024-04-02
  • Java数据结构之双向链表如何实现
    这篇文章主要讲解了“Java数据结构之双向链表如何实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java数据结构之双向链表如何实现”吧!双向链表(Doubly linked list)什...
    99+
    2023-06-30
  • C语言如何实现双向链表
    本篇内容介绍了“C语言如何实现双向链表”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!双向链表的基本操作    ...
    99+
    2023-06-16
  • java实现双向链表的增删改
    双向链表:java实现双向链表的增删改,供大家参考,具体内容如下 单向链表,查找的方向只能是一个方向,而双向链表可以向前或者向后查找 单向链表不能自我删除,需要靠辅助节点,而双向链表...
    99+
    2024-04-02
  • java中的双向链表怎么实现
    在Java中,可以使用自定义的双向链表类来实现双向链表。以下是一个简单的双向链表的实现示例: public class Doubly...
    99+
    2023-10-24
    java
  • Java实现无头双向链表操作
    本文实例为大家分享了Java实现无头双向链表的具体代码,供大家参考,具体内容如下 无头双向链表的结构: 代码分析 节点结构 class Node {     private int...
    99+
    2024-04-02
  • Java数据结构之链表实现(单向、双向链表及链表反转)
    前言 之前学习的顺序表查询非常快,时间复杂度为O(1),但是增删改效率非常低,因为每一次增删改都会元素的移动。可以使用另一种存储方式-链式存储结构。 链表是一种物理存储单元上非连续、...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作