返回顶部
首页 > 资讯 > 后端开发 > Python >Java实现双端链表LinkedList
  • 300
分享到

Java实现双端链表LinkedList

2024-04-02 19:04:59 300人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录一、LinkedList 介绍二、LinkedList 使用一、LinkedList 介绍 1️⃣LinkedList 是 Java 集合框架中一个重要的实现,其底层采用的双向链

一、LinkedList 介绍

1️⃣LinkedList 是 Java 集合框架中一个重要的实现,其底层采用的双向链表结构,没有初始化大小,就是一直在前面或者后面新增就好。由于基于链表实现,存储元素过程中,无需像ArrayList那样进行扩容。
2️⃣LinkedList 存储元素的节点需要额外的空间存储前驱和后继的引用。
3️⃣LinkedList 在链表头部和尾部插入效率比较高,但在指定位置进行插入时,效率一般。原因是,在指定位置插入需要定位到该位置处的节点,此操作的时间复杂度为 O(N)。
4️⃣和 ArrayList 一样,LinkedList 也支持空值和重复值。LinkedList 也是非线程安全的集合类。
5️⃣由于 LinkedList 实现了 List 和 Deque 两个接口,所以 LinkedList 方法分两种,一种是 List 接口的方法,第二种是 Deque 接口的方法。
6️⃣由于 LinkedList 是一个实现了 Deque 的双端队列,所以 LinkedList 既可以当做Queue,又可以当做 Stack。在将 LinkedList 当做 Stack 时,使用 pop()、push()、peek() 需要注意的是 LinkedList 内部是将链表头部当做栈顶,链表尾部当做栈底。
7️⃣随机访问慢、插入删除速度快。

二、LinkedList 使用

import java.util.Iterator;
import java.util.Deque;
import java.util.LinkedList;
import java.util.Queue;


public class LinkedlistDemo {

    public static void main(String[] args) {
        linkedShow();
        System.out.println(">----------一&&&二----------<");
        linkedDeque();
        System.out.println(">----------二&&&三----------<");
        linkedListPop();
    }

    public static void linkedShow() {
        // 创建一个队列
        Queue<Integer> queue = new LinkedList<>();
        //添加元素
        queue.add(1);
        queue.offer(22);
        for (Integer integer : queue) {
            System.out.println("queue的add()和offer()验证:" + integer);
        }

        // 获取但不移除此队列的头
        Integer a = queue.peek();
        // 输出获取的元素并打印出元素的长度,验证一下长度看看是否有变化
        System.out.println("queue.peek():" + a + ",后长度为:" + queue.size());

        // 获取并移除此队列的头
        Integer bInteger = queue.poll();
        // 输出获取的元素并打印出元素的长度,验证一下长度看看是否有变化
        System.out.println("queue.poll():" + bInteger + ",后长度为:" + queue.size());

    }

    public static void linkedDeque() {
        Deque<Integer> deque = new LinkedList<>();
        // 添加元素
        deque.add(3);
        // 在第一个位置添加元素
        deque.offerFirst(5);
        // 在最后一个位置添加元素
        deque.offerLast(7);
        for (Integer integer : deque) {
            System.out.println("deque新增验证:" + integer);
        }
        // 取出不移除元素
        Integer kInteger = deque.peekFirst();
        Integer mInteger = deque.peekLast();
        System.out.println("deque.peek():" + kInteger + ">>>>" + mInteger + ",后长度为:" + deque.size());
        // 取出并移除元素方法
        Integer kInteger2 = deque.pollFirst();
        Integer mInteger2 = deque.pollLast();
        System.out.println("deque.poll():" + kInteger2 + ">>>>" + mInteger2 + ",后长度为:" + deque.size());
    }

    public static void linkedListPop() {
        // 创建一个linkedlist集合
        LinkedList<Integer> linkedList = new LinkedList<>();
        // 添加元素
        linkedList.push(9);
        linkedList.push(7);
        linkedList.push(5);
        linkedList.push(3);
        linkedList.push(1);
        for (Integer integer : linkedList) {
            System.out.println("linkedList.push():" + integer);
        }

        // 使用迭代器进行正向输出
        Iterator<Integer> inIterator = linkedList.iterator();
        while (inIterator.hasNext()) {
            Integer integer = inIterator.next();
            System.out.println(integer);
        }
        System.out.println("-------分割线-------");
        // 使用迭代器反向输出结果
        Iterator<Integer> inIterator1 = linkedList.descendingiterator();
        while (inIterator1.hasNext()) {
            Integer integer = inIterator1.next();
            System.out.println(integer);
        }
        System.out.println("-------分割线-------");
        // 使用for循环进行输出元素并移除
        for (int i = 0; i <= 4; i++) {
            Integer result = linkedList.pop();
            System.out.println("linkedList.pop():" + result + ">------<" + ",后长度为:" + linkedList.size());
        }
    }
}

输出如下:

queue的add()和offer()验证:1
queue的add()和offer()验证:22
queue.peek():1,后长度为:2
queue.poll():1,后长度为:1
>----------一&&&二----------<
deque新增验证:5
deque新增验证:3
deque新增验证:7
deque.peek():5>>>>7,后长度为:3
deque.poll():5>>>>7,后长度为:1
>----------二&&&三----------<
linkedList.push():1
linkedList.push():3
linkedList.push():5
linkedList.push():7
linkedList.push():9
1
3
5
7
9
-------分割线-------
9
7
5
3
1
-------分割线-------
linkedList.pop():1>------<,后长度为:4
linkedList.pop():3>------<,后长度为:3
linkedList.pop():5>------<,后长度为:2
linkedList.pop():7>------<,后长度为:1
linkedList.pop():9>------<,后长度为:0

Process finished with exit code 0

 到此这篇关于Java实现双端链表LinkedList的文章就介绍到这了,更多相关Java 双端链表LinkedList内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Java实现双端链表LinkedList

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

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

猜你喜欢
  • Java实现双端链表LinkedList
    目录一、LinkedList 介绍二、LinkedList 使用一、LinkedList 介绍 1️⃣LinkedList 是 Java 集合框架中一个重要的实现,其底层采用的双向链...
    99+
    2024-04-02
  • Java实现双向链表
    本文实例为大家分享了Java实现双向链表的具体代码,供大家参考,具体内容如下 1、双向链表 1.1 双向链表的每个节点组成包含节点数据,上一个节点(pre),下一个节点(next) ...
    99+
    2024-04-02
  • 数据结构(Java实现)LinkedList与链表(上)
    链表 逻辑结构 无头单向非循环链表:结构简单,一般不会单独用来存数据。实际中更多是作为其他数据结构的子结构,如哈希桶、图的邻接表等等。 无头双向链表:在Java的集合框架库中LinkedList底层实现就是无头双向循环链表。 ...
    99+
    2023-08-30
    数据结构 java 链表
  • Java数据结构之LinkedList从链表到实现
    目录1.ArrayList的缺陷2.LinkedListLinkedList概念LinkedList的使用3.链表的概念及结构4.ArrayList和LinkedList的区别1.A...
    99+
    2023-05-18
    Java LinkedList Java 链表
  • JAVA中怎么实现链表和双向链表
    这篇文章给大家介绍JAVA中怎么实现链表和双向链表,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。JAVA基础:语言中链表和双向链表的实现(转)[@more@]链表是一种重要的数据结构,在程序设计中占有很重要的地位。C语...
    99+
    2023-06-03
  • 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如何实现双向链表”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、双向链表1 双向链表的每个节点组成包含节点数据,上...
    99+
    2023-06-30
  • python实现双链表
    本文实例为大家分享了python实现双链表的具体代码,供大家参考,具体内容如下 实现双链表需要注意的地方 1、如何插入元素,考虑特殊情况:头节点位置,尾节点位置;一般情况:中间位置2...
    99+
    2024-04-02
  • java实现双向链表的增删改
    双向链表:java实现双向链表的增删改,供大家参考,具体内容如下 单向链表,查找的方向只能是一个方向,而双向链表可以向前或者向后查找 单向链表不能自我删除,需要靠辅助节点,而双向链表...
    99+
    2024-04-02
  • java中的双向链表怎么实现
    在Java中,可以使用自定义的双向链表类来实现双向链表。以下是一个简单的双向链表的实现示例: public class Doubly...
    99+
    2023-10-24
    java
  • Java如何实现双向链表功能
    双向链表实现 双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继...
    99+
    2024-04-02
  • Java实现无头双向链表操作
    本文实例为大家分享了Java实现无头双向链表的具体代码,供大家参考,具体内容如下 无头双向链表的结构: 代码分析 节点结构 class Node {     private int...
    99+
    2024-04-02
  • Java实现双链表的示例代码
    目录一、双向链表是什么二、具体方法实现定义结点下标访问异常获取链表长度打印链表清空链表头插法尾插法指定位置插入查找元素删除第一次出现的关键字删除所有值为key的节点三、完整代码一、双...
    99+
    2024-04-02
  • Python实现双向链表
    之前写的单向链表和环形链表都只是单向的,只能单向遍历,不能根据后面的节点获取前面的节点,除非进行反转操作。 双向链表每个节点都有两个指针,这两个指针分别指向前后两个节点,这样就可以从...
    99+
    2024-04-02
  • Java数据结构之双端链表原理与实现方法
    本文实例讲述了Java数据结构之双端链表原理与实现方法。分享给大家供大家参考,具体如下:一、概述:什么时双端链表:链表中保持这对最后一个连点引用的链表从头部插入要对链表进行判断,如果为空则设置尾节点为新添加的节点从尾部进行插入如果链表为空,...
    99+
    2023-05-30
    java 数据结构 双端链表
  • Java数据结构之链表实现(单向、双向链表及链表反转)
    前言 之前学习的顺序表查询非常快,时间复杂度为O(1),但是增删改效率非常低,因为每一次增删改都会元素的移动。可以使用另一种存储方式-链式存储结构。 链表是一种物理存储单元上非连续、...
    99+
    2024-04-02
  • java双向循环链表的实现代码
    例1:复制代码 代码如下:package com.xlst.util; import java.util.HashMap;import java.util.Map;import ja...
    99+
    2022-11-15
    java 双向循环链表
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作