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

相关推荐

  • 《重构:改善既有代码的设计(第2版)》PDF、EPUB免费下载

    电子版仅供预览,下载后24小时内务必删除,支持正版,喜欢的请购买正版书籍 点击原文去下载 书籍信息 作者: [美] Martin Fowler出版社: 人民邮电出版社出品方: 异步图书副标题: 改善既有代码的设计原作名: Refactoring: Improving the Design of Existing Code,Second Edition译者: …

    2025 年 1 月 10 日
    32000
  • 履约系统:发货单、配送单模型设计详解

    大家好,我是汤师爷~ 概念模型设计是系统开发的关键步骤,它能帮助我们厘清业务逻辑并定义核心实体。我们将从订单履约的基本概念入手,深入探讨各实体间的关系。 履约域核心概念模型 如图展示了履约域的核心概念模型。 1、发货单 发货单是订单履约过程中的重要执行单据,它将订单转化为具体的发货任务。门店和仓储部门通过发货单进行拣货、打包并安排物流服务商发货。发货单确保货…

    2024 年 12 月 31 日
    30600
  • MySql 9 in Docker 主从切换

    继上一篇《MySql 9 in Docker 利用克隆插件搭建主从》我们说了主从复制后, 那么我们接下来说说如何手动的进行主从切换。 动手~ 1. 原主库设置 切断应用对主库的访问 主库设置为只读状态 set global read_only=ON;set global super_read_only=ON; 主库执行 SELECT @@gtid_execu…

    未分类 2024 年 12 月 24 日
    42700
  • 履约系统:应用层、领域层、集成关系设计

    大家好,我是汤师爷~ 在这篇文章中,我们一起探讨订单履约系统的应用架构设计。 应用架构设计 我们前面讨论了系统的核心概念模型和拆单逻辑。接下来,让我们从应用架构的角度,深入了解系统的各个层次。这包括应用层、领域层,以及与其他系统的集成关系。 应用层能力 应用层定义软件的应用功能,它负责接收用户请求,协调领域层能力来执行任务,并将结果返回给用户,核心模块包括:…

    2025 年 1 月 1 日
    28100
  • IoC究竟是什么?——IoC的基础分析

    IoC全称Inversion of Control,直译为控制反转。这是一种设计理念,并非技术。在明白控制反转之前,应该知道“反转”反的是什么。 被反转的正转 我们从生活中的做饭场景开始。 在家做菜与餐馆吃饭 我们在做饭的时候有很多个步骤,需要准备原料,厨具等等。最后通过一定的顺序加入我们的原料,再进行翻炒等烹饪操作就能够得到一份菜了。我们想吃一份菜不一定需…

    未分类 2025 年 1 月 13 日
    33400

发表回复

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

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

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

关注微信