我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Java如何实现双向链表

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Java如何实现双向链表

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Java如何实现双向链表

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

下载Word文档

猜你喜欢

Java如何实现双向链表

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

C语言如何实现双向链表和双向循环链表

本文小编为大家详细介绍“C语言如何实现双向链表和双向循环链表”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言如何实现双向链表和双向循环链表”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。双向链表和双向循环链表
2023-06-16

java双向链表怎么实现

Java中的双向链表可以通过定义一个Node类来实现,该类包含一个值和两个指针,分别指向前一个节点和后一个节点。具体实现如下:public class DoublyLinkedList {private Node head; // 链表头
2023-10-22

java如何实现双向链表的增删改

这篇文章主要介绍“java如何实现双向链表的增删改”,在日常操作中,相信很多人在java如何实现双向链表的增删改问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java如何实现双向链表的增删改”的疑惑有所帮助!
2023-06-30

java 中的双向链表是如何实现的

这篇文章将为大家详细讲解有关java 中的双向链表是如何实现的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。java 实现双向链表实例详解 双向链表是一个基本的数据结构,在Java中Link
2023-05-31

JAVA中怎么实现链表和双向链表

这篇文章给大家介绍JAVA中怎么实现链表和双向链表,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。JAVA基础:语言中链表和双向链表的实现(转)[@more@]链表是一种重要的数据结构,在程序设计中占有很重要的地位。C语
2023-06-03

利用Java如何实现一个双向链表

利用Java如何实现一个双向链表?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Java中双向链表详解及实例写在前面:  双向链表是一种对称结构,它克服了单链表上
2023-05-31

Java如何实现无头双向链表操作

这篇文章主要介绍了Java如何实现无头双向链表操作,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体内容如下无头双向链表的结构:代码分析节点结构class Node {
2023-06-28

Java数据结构之双向链表如何实现

这篇文章主要讲解了“Java数据结构之双向链表如何实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java数据结构之双向链表如何实现”吧!双向链表(Doubly linked list)什
2023-06-30

C语言如何实现双向链表

本篇内容介绍了“C语言如何实现双向链表”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!双向链表的基本操作 1.利用尾插法建立一个双向链表
2023-06-16

java中的双向链表怎么实现

在Java中,可以使用自定义的双向链表类来实现双向链表。以下是一个简单的双向链表的实现示例:public class DoublyLinkedList {private Node head; // 链表头节点private Node ta
2023-10-24

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录