Java中的LinkedList(链表)(如果想知道Java中有关LinkedList的知识点,那么只看这一篇就足够了!)

在Java中,LinkedList是一个实现了List接口的链表数据结构,它允许在近乎于零的时间内对列表的首部或尾部进行插入和删除操作。LinkedList还可以用作队列或栈。

以下是一些常用的LinkedList方法:

  • add(E e): 在列表的尾部添加元素。
  • add(int index, E element): 在指定位置插入元素。
  • remove(int index): 移除列表中指定位置的元素。
  • remove(Object o): 移除列表中第一次出现的指定元素。
  • get(int index): 返回列表中指定位置的元素。
  • set(int index, E element): 用指定元素替换列表中指定位置的元素。
  • addFirst(E e): 将元素添加到列表的开头。
  • addLast(E e): 将元素添加到列表的末尾。
  • getFirst(): 返回列表的第一个元素。
  • getLast(): 返回列表的最后一个元素。
  • removeFirst(): 移除并返回列表的第一个元素。
  • removeLast(): 移除并返回列表的最后一个元素。
  • peek(): 查看队列的第一个元素,但不移除。
  • poll(): 移除并返回队列的第一个元素。
  • push(E e): 将元素推入栈顶。
  • pop(): 移除栈顶元素。

示例代码:




import java.util.LinkedList;
 
public class LinkedListExample {
    public static void main(String[] args) {
        LinkedList<String> linkedList = new LinkedList<>();
 
        // 添加元素
        linkedList.add("A");
        linkedList.add("B");
        linkedList.add("C");
 
        // 在首部添加元素
        linkedList.addFirst("0");
 
        // 在尾部添加元素
        linkedList.addLast("D");
 
        // 查看元素
        System.out.println(linkedList); // 输出: [0, A, B, C, D]
 
        // 获取首元素
        System.out.println(linkedList.getFirst()); // 输出: 0
 
        // 获取尾元素
        System.out.println(linkedList.getLast()); // 输出: D
 
        // 移除首元素
        linkedList.removeFirst();
 
        // 移除尾元素
        linkedList.removeLast();
 
        // 查看元素
        System.out.println(linkedList); // 输出: [A, B, C]
 
        // 使用栈的方式使用LinkedList
        LinkedList<String> stack = new LinkedList<>();
        stack.push("A");
        stack.push("B");
        System.out.println(stack); // 输出: [B, A]
        System.out.println(stack.pop()); // 输出: B
        System.out.println(stack.pop()); // 输出: A
 
        // 使用队列的方式使用LinkedList
        LinkedList<String> queue = new LinkedList<>();
        queue.offer("A");
        queue.offer("B");
        System.out.println(queue); // 输出: [A, B]
        System.out.println(queue.poll()); // 输出: A
        System.out.println(queue.poll()); // 输出: B
    }
}

以上代码演示了\`

最后修改于:2024年08月07日 10:08

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日