数据结构-链表

链表的概念

链表是一种物理存储结构上非连续存储结构 ,数据元素的逻辑顺序是通过链表中的引用连接次序实现的

链表结构非常多样,总共分为8种

1.单向或者双向

2.带头或者不带头

链表的头部也称为哨兵位一般不存储数据,一直作为头部

3.循环或者非循环

我们一般掌握:

无头单向非循环链表(单链表):一般不会单独用来存数据,实际中是作为其他数据结构的子结构

无头双向非循环链表(双链表) :在Java的集合框架库中LinkedList底层实现就是无头双向循环链表

LinkedList的使用

LinkedList的底层是双向链表结构

在集合框架中,LinkedList也实现了List接口

注意

LinkedList不支持随机访问且任意位置插入和删除元素的效率比较高,时间复杂度为O(1)

LinkedList的构造

java 复制代码
LinkedList<Integer> list=new LinkedList<>();
List<Integer> list2=new LinkedList<>();

LinkedList常用方法

remove会返回被删除的元素 ,subList截取的是元素的地址 ,也就是说通过返回值仍可以对原链表进行修改

LinkedList的遍历

java 复制代码
  // foreach遍历
    for (int e:list) {
        System.out.print(e + " ");
   }
    System.out.println();
    // 使用迭代器遍历---正向遍历
    ListIterator<Integer> it = list.listIterator();
    while(it.hasNext()){
        System.out.print(it.next()+ " ");
   }
    System.out.println();
    // 使用反向迭代器---反向遍历
    ListIterator<Integer> rit = list.listIterator(list.size());
    while (rit.hasPrevious()){
        System.out.print(rit.previous() +" ");
   }
    System.out.println();
}

ArrayList和LinkedList的区别

栈和队列

栈:一种特殊的线性表 ,其只允许在固定的一端进行插入和删除元素 。进行数据插入和删除操作的一端是栈顶,另一端是栈底。栈中的数据遵循后进先出的LIFO原则

压栈:栈的插入操作叫做进栈/压栈/入栈,数据在栈顶

出栈:栈的删除操作,出的数据在栈顶

栈的使用

LinkedList也可以当作栈来使用,方法均是通用的

栈的应用场景

改变元素的序列

将递归转化为循环

比如:对链表进行逆序打印

递归:

java 复制代码
  public static void Print1(MyLinkedList.ListNode head){
        if(head.next!=null){
             Print1(head.next);
        }
        System.out.print(head.data+" ");

    }

循环:

java 复制代码
    public static void Print2(MyLinkedList.ListNode head){
        Stack<MyLinkedList.ListNode> stack=new Stack<>();
        while(head!=null){
            stack.push(head);
            head=head.next;
        }
        while(!stack.empty()){
            System.out.print(stack.pop().data+" ");
        }
        System.out.println();
    }

栈:一种数据结构

栈帧:运行方法时给方法开辟的内存

虚拟机栈:内存

队列

只允许在一端进行插入数据操作,在另一端进行删除操作的特殊线性表,队列是先进先出入队列: 在进行插入 操作的一端称为队尾出队列: 进行删除 操作的一端称为队头

队列的使用

在Java中,Queue是一个接口 ,底层通过链表实现

注意: Queue是一个接口,在实例化时必须先实例化LinkedList的对象 ,因为LinkedList实现了Queue的接口

循环队列

在实际中我们还会使用到循环列队,比如操作系统课程讲解生产者和消费者模型的时候就会使用循环列队,环形列队通常使用数组实现

1.数组下标往后时 index=(index+offset)%array.length

2.数组下标往前遍历时,使用index=(index+array.length-offset)%array.length

如何区分空和满:

1.通过size属性记录

2.保留一个位置

3.使用标记

双端队列

双端队列是指允许两端都可以进行入队和出队操作。

Deque是一个接口,使用时必须创建LinkedList对象

栈和队列都可以通过此接口来实现

java 复制代码
Deque<Integer> stack = new ArrayDeque<>();//双端队列的线性实现
Deque<Integer> queue = new LinkedList<>();//双端队列的链式实现
相关推荐
xuhaoyu_cpp_java12 小时前
项目学习(三)代码生成器
java·经验分享·笔记·学习
乐观勇敢坚强的老彭12 小时前
C++信息学奥赛lesson1
java·开发语言·c++
San813_LDD12 小时前
[深度学习] 数据序列化格式对比:以日志级别配置为例
xml·java·前端
github_czy12 小时前
更加优雅的类型检查与传参---mcp源码分析
java·服务器·开发语言
专注_每天进步一点点12 小时前
IDEA中,Apifox Helper 的 2.0.15-243版本的插件 导出指定的接口,入参的中文名为空,描述为空
java·ide·intellij-idea
兰令水12 小时前
leecodecode【区间DP+树形DP】【2026.6.10打卡-java版本】
java·算法·leetcode
小刘|13 小时前
Spring WebFlux + AI 流式输出深度解析:Spring AI 与 LangChain4j 效果差异溯源
java·后端·spring
worilb13 小时前
Spring Cloud 学习与实践(8):Spring Cloud Gateway 统一入口、路由转发与双重跨域故障演练
学习·spring·spring cloud
初圣魔门首席弟子13 小时前
学习工作方法论与任务执行计划
学习
budingxiaomoli13 小时前
二叉树中的深搜
数据结构