Java的栈与队列以及代码实现

Java中的栈与队列

栈的基本概念(Stack)

栈是一种基本的线性数据结构,遵循后进先出(LIFO)的原则。这意味着最后加入的元素将是第一个被移除的。栈的应用非常广泛,包括内存分配、表达式求值、临时数据存储以及方法调用等。以子弹夹为例,最先装填的子弹位于底部(栈底),而最后装填的子弹位于顶部(栈顶)。只有当顶部的子弹被射出后,底部的子弹才有机会发射。

栈的可视化

栈的实现方式

栈可以通过数组来实现,我们可以将其想象为一个连续的数组,元素的添加和移除都发生在数组的一端。以下是模拟栈操作的基本方法:push(向栈中添加元素),pop(从栈中移除顶部元素),peek(查看栈顶元素),size(获取栈中元素的数量),empty(检查栈是否为空),full(检查栈是否已满)。

栈的数组实现

栈的代码实现

import java.util.Arrays;

public class MyStack {
    private int[] elem;
    private int top; // 栈顶索引
    private static final int DEFAULT_CAPACITY = 10; // 初始容量

    public MyStack() {
        elem = new int[DEFAULT_CAPACITY];
        top = -1; // 索引从0开始
    }

    public void push(int item) {
        if (full()) {
            // 栈满时扩容
            elem = Arrays.copyOf(elem, 2 * elem.length);
        }
        elem[++top] = item;
    }

    public int pop() {
        if (empty()) {
            throw new RuntimeException("栈为空");
        }
        return elem[top--];
    }

    public int peek() {
        if (empty()) {
            throw new RuntimeException("栈为空");
        }
        return elem[top];
    }

    public int size() {
        return top + 1;
    }

    public boolean empty() {
        return top == -1;
    }

    public boolean full() {
        return top == elem.length - 1;
    }
}

队列(Queue)

队列是另一种线性数据结构,遵循先进先出(FIFO)的原则。元素的添加操作在队列的尾部进行,而元素的移除操作在队列的头部进行。

队列的可视化

队列的模拟实现(双链表)

```java
public class MyQueue {
static class QueueNode {
public int elem;
public QueueNode next;
public QueueNode prev;
public QueueNode(int elem) {
this.elem = elem;
}
}

public QueueNode head;
public QueueNode last;
public int size = 0;

public void offer(int val) {
    QueueNode queue = new QueueNode(val);
    if (head == null) {
        head = queue;
        last = queue;
        ++size;
        return;
    }
    last.next = queue;
    queue.prev = head;
    last = queue;
    ++size;
}

public int poll() {
    if (head == null) {
        throw new RuntimeException("队列为空");
    }
    QueueNode cur = head;
    if (head.next == null) {
        head = null;
        last = null;
    } else {
        head = head.next;
        head.prev = null;
    }
    --size;
    return cur.elem;
}

public int peek() {
    if (head != null) {
        return head.elem;
    }
    return 0;
}

public int size() {
    return size;

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/4490.html

(0)
LomuLomu
上一篇 2024 年 12 月 27 日 下午3:08
下一篇 2024 年 12 月 27 日 下午4:09

相关推荐

  • SpringBoot3整合Swagger3时出现Type javax.servlet.http.HttpServletRequest not present错误

    目录 错误详情 错误原因 解决方法 引入依赖 修改配置信息 创建文件 访问 错误详情 错误原因 SpringBoot3和Swagger3版本不匹配 解决方法 使用springdoc替代springfox,具体步骤如下: 引入依赖 在pom.xml文件中添加如下依赖: org.springdoc springdoc-openapi-starter-webmvc…

    2025 年 1 月 19 日
    74000
  • Java 并发编程:ReentrantLock 锁与 AQS

    大家好,我是栗筝i,这篇文章是我的“栗筝i的Java技术栈”专栏的第030篇作品。在这个专栏中,我将不断为大家带来涵盖Java技术全领域的深入内容。本专栏旨在帮助那些已经具备一定Java开发基础,并且渴望全面掌握Java技术体系以丰富自身技术储备的开发者。同时,每篇文章都会提供丰富的代码示例和详尽的知识点总结,非常适合初学者和即将参加工作面试的求职者。当然,…

    未分类 2024 年 12 月 28 日
    66500
  • 『玩转Streamlit』–查看K线的小工具

    在金融市场分析中,查看不同交易对的 K 线数据是一项基础且重要的工作。 今天,我们就来学习如何使用 Streamlit 构建一个简单的 K 线查看小工具,让你能够方便地查看不同交易对在不同时间范围内的 K 线数据。 1. 环境准备 首先,确保已经安装了必要的库。 除了 Streamlit 用于构建界面,还需要pandas 用于数据处理,plotly 用于绘制…

    2025 年 1 月 14 日
    62100
  • JavaScript 延迟加载的方法( 7种 )

    JavaScript脚本的延迟加载(也称为懒加载)是指在网页的主要内容已经加载并显示给用户之后,再加载或执行额外的JavaScript代码。这样做可以加快页面的初始加载速度,改善用户体验,并减少服务器的压力。 以下是几种常见的延迟加载JavaScript的方法: defer 属性: 使用 async 属性: async 属性告诉浏览器立即开始下载脚本,并且在…

    2025 年 1 月 5 日
    56700
  • Java难绷知识02——抽象类中只能有或者必须有抽象方法吗以及有关抽象类的细节探讨

    Java难绷知识02——抽象类中只能有或者必须有抽象方法吗以及有关抽象类的细节探讨 标题长的像轻小说 首先回答标题抛出的问题——False 显然,有抽象方法的类是抽象类,但是,抽象类中只能有或者必须有抽象方法吗? 抽象类可以包含抽象方法,也可以包含具体方法 如果一个类包含至少一个抽象方法,用abstract关键字修饰,那么这个类必须被声明为抽象类。 抽象类除…

    未分类 2024 年 12 月 31 日
    57700

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信