Java实现双端链表LinkedList

目录
  • 一、LinkedList 介绍
  • 二、LinkedList 使用

一、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内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Java实现单链表SingleLinkedList增删改查及反转 逆序等

    节点类 可以根据需要,对节点属性进行修改.注意重写toString()方法,以便后续的输出操作. //节点类 class Node { public int id; public String name; public Node next; public Node(int id, String name) { this.id = id; this.name = name; } @Override public String toString() { return "Node{" + &

  • Java实现双端链表LinkedList

    目录 一.LinkedList 介绍 二.LinkedList 使用 一.LinkedList 介绍 1️⃣LinkedList 是 Java 集合框架中一个重要的实现,其底层采用的双向链表结构,没有初始化大小,就是一直在前面或者后面新增就好.由于基于链表实现,存储元素过程中,无需像ArrayList那样进行扩容.2️⃣LinkedList 存储元素的节点需要额外的空间存储前驱和后继的引用.3️⃣LinkedList 在链表头部和尾部插入效率比较高,但在指定位置进行插入时,效率一般.原因是,在指

  • Java数据结构之双端链表原理与实现方法

    本文实例讲述了Java数据结构之双端链表原理与实现方法.分享给大家供大家参考,具体如下: 一.概述: 1.什么时双端链表: 链表中保持这对最后一个连点引用的链表 2.从头部插入 要对链表进行判断,如果为空则设置尾节点为新添加的节点 3.从尾部进行插入 如果链表为空,则直接设置头节点为新添加的节点,否则设置尾节点的后一个节点为新添加的节点 4.从头部删除 判断节点是否有下个节点,如果没有则设置节点为null 二.具体实现 /** * @描述 头尾相接的链表 * @项目名称 Java_DataStr

  • Java模拟单链表和双端链表数据结构的实例讲解

    模拟单链表 线性表: 线性表(亦作顺序表)是最基本.最简单.也是最常用的一种数据结构. 线性表中数据元素之间的关系是一对一的关系,即除了第一个和最后一个数据元素之外,其它数据元素都是首尾相接的. 线性表的逻辑结构简单,便于实现和操作. 在实际应用中,线性表都是以栈.队列.字符串等特殊线性表的形式来使用的. 线性结构的基本特征为: 1.集合中必存在唯一的一个"第一元素": 2.集合中必存在唯一的一个 "最后元素" : 3.除最后一个元素之外,均有 唯一的后继(后件):

  • Java超详细精讲数据结构之bfs与双端队列

    目录 一.bfs 二.双端队列 三.算法题 1.kotori和迷宫 2.小红找红点 3.小红玩数组 一.bfs bfs(广度优先搜索),类似二叉树的层序遍历,利用队列完成.一般用于求最短路. 图的最短路问题: 给定一个无向图,每条边的长度都是1.求1号点到x号点的最短距离. 顶点数n 边数为m q次询问 输入x 输出1到x的最短距离. 若1号点到x不连通,则输出-1 二.双端队列 双端队列的应用(区间翻转): 对于长度为n的数组,给定一个长度为m的区间,区间初始位置为a[1]到a[m]. 3种操

  • Java实现双链表的示例代码

    目录 一.双向链表是什么 二.具体方法实现 定义结点 下标访问异常 获取链表长度 打印链表 清空链表 头插法 尾插法 指定位置插入 查找元素 删除第一次出现的关键字 删除所有值为key的节点 三.完整代码 一.双向链表是什么 双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱.所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点.一般我们都构造双向循环链表. LinkedList底层就是一个双向链表,我们来实现一个双向链表. 这

  • Java实现双链表互相交换任意两个节点的方法示例

    本文实例讲述了Java实现双链表互相交换任意两个节点的方法.分享给大家供大家参考,具体如下: 概述: 双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱.所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点.一般我们都构造双向循环链表. 思路: 1.确定两个节点的先后顺序 2.next.prev互相交换顺序以及将换向前方的节点与之前的节点对接.(1.prev.next = 2) 3.判断是否相邻 实现代码: 链表类: publi

  • 区分Java中的ArrayList和LinkedList

    一:ArrayList和LinkedList的大致区别如下: 1.ArrayList是实现了基于动态数组的数据结构,ArrayList实现了长度可变的数组,在内存中分配连续的空间.遍历元素和随机访问元素的效率比较高 2.LinkedList基于链表的数据结构, 插入.删除元素时效率比较高  故:[插入.删除操作频繁时,可使用LinkedList来提高效率]LinkedList提供对头部和尾部元素进行添加和删除操作的方法,插入/删除第一个和最后一个效率比较高: 3:ArrayList和Linked

  • JS中的算法与数据结构之链表(Linked-list)实例详解

    本文实例讲述了JS中的算法与数据结构之链表(Linked-list).分享给大家供大家参考,具体如下: 链表(Linked-list) 前面我们讨论了如何使用栈.队列进行存数数据,他们其实都是列表的一种,底层存储的数据的数据结构都是数组. 但是数组不总是最佳的数据结构,因为,在很多编程语言中,数组的长度都是固定的,如果数组已被数据填满,再要加入新的元素是非常困难的.而且,对于数组的删除和添加操作,通常需要将数组中的其他元素向前或者向后平移,这些操作也是十分繁琐的. 然而,JS中数组却不存在上述问

  • java实现简单单链表

    本文实例为大家分享了java实现简单单链表的具体代码,供大家参考,具体内容如下 一.定义: 单链表是一种链式存取的数据结构,用一组地址任意的存储单元存放线性表中的数据元素.链表中的数据是以结点来表示的,每个结点的构成:元素(数据元素的映象) + 指针(相当于JAVA中的引用,指示后继元素存储位置,),元素就是存储数据的存储单元,指针就是连接每个结点的地址数据. 二.结构: 如图所示,data就是当前节点的数据,next是指针,指针存放的是内存地址,是当前结点的下一结点内存地址,顺着这个地址就能找

  • Java如何实现单链表的增删改查

    一.新建学生节点类 Stu_Node节点包含: 学号:int num; 姓名:String name; 性别:String gender; 下一个节点:Stu_Node next; 为了便于打印节点内容需要重写toString方法 class Stu_Node{ int num; String name; String gender; Stu_Node next; @Override public String toString() { return "Stu_Node{" + &qu

随机推荐