Java实现双向链表(两个版本)

下面是详细讲解Java实现双向链表的完整攻略。

双向链表定义

双向链表是链表的一种,每个节点都包含两个指针,一个指向前一个节点,一个指向后一个节点。相对于单向链表,双向链表可以实现双向遍历,但是占用空间较大。

双向链表的实现

版本一

双向链表的每个节点需要维护前向指针和后向指针,因此我们可以定义一个Node类来封装节点信息,再定义一个双向链表类来封装链表信息。

Node类定义如下:

class Node {
    int data;
    Node prev;
    Node next;

    public Node(int data) {
        this.data = data;
        this.prev = null;
        this.next = null;
    }
}

双向链表类定义如下:

class DoubleLinkedList {
    Node head;
    Node tail;

    public DoubleLinkedList() {
        this.head = null;
        this.tail = null;
    }

    public void add(int data) {
        Node newNode = new Node(data);
        if (head == null) {
            head = newNode;
            tail = newNode;
        } else {
            tail.next = newNode;
            newNode.prev = tail;
            tail = newNode;
        }
    }

    public void printFromHead() {
        Node current = head;
        while (current != null) {
            System.out.print(current.data + " ");
            current = current.next;
        }
        System.out.println();
    }

    public void printFromTail() {
        Node current = tail;
        while (current != null) {
            System.out.print(current.data + " ");
            current = current.prev;
        }
        System.out.println();
    }
}

这里定义了头节点和尾节点两个指针,add方法用于向链表中添加新节点,printFromHead和printFromTail方法用于从头节点和尾节点打印链表。

示例一:

DoubleLinkedList list = new DoubleLinkedList();
list.add(1);
list.add(2);
list.add(3);
list.printFromHead(); // 1 2 3
list.printFromTail(); // 3 2 1

版本二

在版本一的实现中,我们每次在尾节点添加新节点时需要遍历整个链表,因此时间复杂度较高。我们可以在链表类中添加一个变量count,用于记录链表节点的数量,然后在添加新节点时直接将其插入到尾节点之后,省去了遍历的过程。

双向链表类定义如下:

class DoubleLinkedList {
    Node head;
    Node tail;
    int count;

    public DoubleLinkedList() {
        this.head = null;
        this.tail = null;
        this.count = 0;
    }

    public void add(int data) {
        Node newNode = new Node(data);
        if (head == null) {
            head = newNode;
            tail = newNode;
        } else {
            tail.next = newNode;
            newNode.prev = tail;
            tail = newNode;
        }
        count++;
    }

    public void printFromHead() {
        Node current = head;
        while (current != null) {
            System.out.print(current.data + " ");
            current = current.next;
        }
        System.out.println();
    }

    public void printFromTail() {
        Node current = tail;
        while (current != null) {
            System.out.print(current.data + " ");
            current = current.prev;
        }
        System.out.println();
    }
}

示例二:

DoubleLinkedList list = new DoubleLinkedList();
list.add(1);
list.add(2);
list.add(3);
list.printFromHead(); // 1 2 3
list.printFromTail(); // 3 2 1

总结

双向链表是一种非常常用的数据结构,在实际开发中也经常用到。上述是两种Java实现双向链表的方法,考虑实际情况和需求选择适合自己的实现方法。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Java实现双向链表(两个版本) - Python技术站

(0)
上一篇 2023年6月27日
下一篇 2023年6月27日

相关文章

  • java内存分布实现代码

    Java内存分布实现代码攻略 Java内存分布是指Java程序在运行时如何分配和管理内存。了解Java内存分布对于理解Java程序的性能和内存使用情况非常重要。下面是一个详细的攻略,介绍了Java内存分布的实现代码和示例。 1. Java内存分布概述 Java内存分布主要包括以下几个部分: 方法区(Method Area):用于存储类的信息、静态变量、常量等…

    other 2023年8月1日
    00
  • iPhone5s运行iOS10开发者预览版Beta8与iOS9.3.5速度对比评测

    首先,为了评测iPhone 5s运行iOS 10开发者预览版Beta8与iOS 9.3.5的速度对比,我们需要准备以下材料: 一台iPhone 5s; iOS 10开发者预览版Beta8系统文件; iOS 9.3.5系统文件; iTunes; 一台配有Mac操作系统的电脑; 闪存驱动器(可选)。 接下来,我们需要执行以下步骤: 步骤一:备份现有数据 首先,在…

    other 2023年6月26日
    00
  • C/C++实现投骰子游戏

    首先,我们需要确定投骰子游戏的规则和逻辑。 投骰子游戏通常由两个及以上玩家进行,每个玩家轮流投掷骰子,将骰子点数相加计算得分,总分数高者获胜。在每次投掷后,玩家可以选择停止投掷并计算得分,也可以继续投掷骰子。如果在投掷过程中出现了骰子点数之和等于7的情况,本轮该玩家得分清零。 基于这个规则,我们可以开始进行C/C++实现投骰子游戏的编写。 定义骰子点数范围和…

    other 2023年6月26日
    00
  • 分享Android开发自学笔记之AndroidStudio常用功能

    分享Android开发自学笔记之AndroidStudio常用功能攻略 介绍 本攻略将详细讲解AndroidStudio中的常用功能,帮助您更好地进行Android开发。以下是一些示例说明。 1. 代码自动补全 AndroidStudio提供了强大的代码自动补全功能,可以大大提高编码效率。当您输入代码时,它会根据上下文和已有的代码提示您可能需要的代码片段。 …

    other 2023年8月25日
    00
  • CSS 优先级问题详解

    CSS 优先级问题详解 1. 什么是 CSS 优先级? 在 CSS 中,当多个样式规则同时应用于同一个元素时,可能会出现冲突。这时就需要确定应该使用哪个样式规则来渲染元素,这个决定是由 CSS 优先级来控制的。CSS 优先级是根据选择器的特殊性和源代码的顺序来确定的。 2. CSS 优先级的计算规则 CSS 优先级的计算规则如下: 内联样式具有最高的优先级。…

    other 2023年6月28日
    00
  • 在python里面运用多继承方法详解

    首先我将采用Markdown的格式查看“在Python里面运用多继承方法详解”这个主题。 在Python里面运用多继承方法详解 在Python中,多继承是一种常见的面向对象编程技术,它允许一个类同时继承多个父类,并从这些父类继承属性和方法。这种方法带来了许多便利,但也需要我们在程序设计时慎重考虑。 多继承的基本语法 多继承的基本语法如下所示: class D…

    other 2023年6月26日
    00
  • FTP上传工具哪个好用?2018年六款最常用的的FTP上传工具推荐

    FTP上传工具哪个好用?2018年六款最常用的的FTP上传工具推荐 什么是FTP上传工具? FTP上传工具是一种可以用来将文件上传至服务器的工具,其使用的方式为用户将需要上传的文件本地编辑保存好后使用FTP上传工具将其上传至服务器。 FTP上传工具有哪些? 2018年的FTP上传工具主要有以下六款: FileZilla WinSCP FireFTP Cybe…

    other 2023年6月27日
    00
  • Kotlin作用域函数使用示例详细介绍

    Kotlin作用域函数使用示例详细介绍 Kotlin提供了几个作用域函数,它们可以在对象上执行代码块,并且在代码块内部可以方便地访问该对象的属性和方法。本攻略将详细介绍以下几个作用域函数的使用示例:let、run、with和apply。 1. let函数 let函数允许您在对象上执行代码块,并且可以在代码块内部访问该对象的属性和方法。它的返回值是代码块的最后…

    other 2023年8月19日
    00
合作推广
合作推广
分享本页
返回顶部