浅谈数据结构之栈

news/2024/7/5 5:25:43

数据结构是计算机科学的基础之一,栈(Stack)是其中一个重要的数据结构之一。栈是一种线性数据结构,它遵循“后进先出”(Last In, First Out,LIFO)原则,意味着最后入栈的元素将首先被取出。在本文中,我们将深入研究栈的原理、创建方式、使用场景以及时间复杂度。

原理

栈是一种基于数组或链表的数据结构,它由两个主要操作组成:

  1. 入栈(Push):将元素添加到栈的顶部。
  2. 出栈(Pop):从栈的顶部移除元素。

栈的顶部被称为栈顶(Top),底部被称为栈底(Bottom)。栈内的元素排列有序,最后入栈的元素总是最靠近栈顶。由于LIFO原则,栈通常用于跟踪方法调用、表达式求值和管理临时数据。

创建方式

import java.util.EmptyStackException;

// 数据结构中的栈:原理、创建、应用和时间复杂度详解
public class Stack<T> {
    private static final int DEFAULT_CAPACITY = 10;
    private T[] elements;
    private int size;

    // 栈的构造函数
    public Stack() {
        elements = (T[]) new Object[DEFAULT_CAPACITY];
        size = 0;
    }

    // 入栈操作
    public void push(T element) {
        if (size == elements.length) {
            ensureCapacity();
        }
        elements[size++] = element;
    }

    // 出栈操作
    public T pop() {
        if (isEmpty()) {
            throw new EmptyStackException();
        }
        T element = elements[--size];
        elements[size] = null; // Help with garbage collection
        return element;
    }

    // 查看栈顶元素
    public T top() {
        if (isEmpty()) {
            throw new EmptyStackException();
        }
        return elements[size - 1];
    }

    // 检查栈是否为空
    public boolean isEmpty() {
        return size == 0;
    }

    // 获取栈的大小
    public int size() {
        return size;
    }

    // 扩展栈容量
    private void ensureCapacity() {
        int newCapacity = elements.length * 2;
        elements = Arrays.copyOf(elements, newCapacity);
    }

    // 主方法演示栈的使用
    public static void main(String[] args) {
        Stack<Integer> stack = new Stack<>();
        stack.push(1);
        stack.push(2);
        stack.push(3);

        System.out.println("栈顶元素: " + stack.top()); // 输出 "栈顶元素: 3"

        while (!stack.isEmpty()) {
            System.out.println("出栈: " + stack.pop());
        }
    }
}

使用场景

栈在计算机科学中有许多应用场景,包括但不限于:

方法调用和递归:栈用于存储函数调用的返回地址和局部变量。
表达式求值:栈可用于跟踪操作符和操作数,以计算数学表达式的结果。
浏览器前进和后退:浏览器使用两个栈来跟踪访问的页面,一个用于前进,一个用于后退。
括号匹配:栈可用于检查括号、大括号和方括号的匹配情况。
历史记录:许多应用程序使用栈来跟踪用户活动的历史记录。

时间复杂度

栈的基本操作的时间复杂度如下:

入栈(Push):O(1) - 在栈顶添加元素,时间复杂度是常数。
出栈(Pop):O(1) - 从栈顶移除元素,时间复杂度是常数。
查看栈顶元素(Top):O(1) - 获取栈顶元素的时间复杂度是常数。
检查栈是否为空(isEmpty):O(1) - 检查栈是否为空的时间复杂度是常数。

总体而言,栈是一个高效的数据结构,适用于许多实际应用中。


http://lihuaxi.xjx100.cn/news/1726711.html

相关文章

【面试经典150 | 栈】最小栈

文章目录 Tag题目来源题目解读解题思路方法一&#xff1a;辅助栈方法二&#xff1a;一个栈方法三&#xff1a;栈中存放差值 其他语言python3 写在最后 Tag 【设计类】【栈】 题目来源 155. 最小栈 题目解读 本题是一个设计类的题目&#xff0c;设计一个最小栈类 MinStack() …

[论文笔记]GTE

引言 今天带来今年的一篇文本嵌入论文GTE, 中文题目是 多阶段对比学习的通用文本嵌入。 作者提出了GTE,一个使用对阶段对比学习的通用文本嵌入。使用对比学习在多个来源的混合数据集上训练了一个统一的文本嵌入模型,通过在无监督预训练阶段和有监督微调阶段显著增加训练数…

第7期 | GPTSecurity周报

GPTSecurity是一个涵盖了前沿学术研究和实践经验分享的社区&#xff0c;集成了生成预训练 Transformer&#xff08;GPT&#xff09;、人工智能生成内容&#xff08;AIGC&#xff09;以及大型语言模型&#xff08;LLM&#xff09;等安全领域应用的知识。在这里&#xff0c;您可以…

javascript之for循环介绍

javascript之for循环介绍 1&#xff09;语法&#xff1a; for ([initialization]; [condition]; [final-expression]) { // code to be executed }1&#xff09;initialization&#xff08;初始化&#xff09;&#xff1a;在循环开始之前执行&#xff0c;通常用于设置循环计…

【爬虫】charles手机抓包环境设置(设置系统证书)

1.说明 想要对手机抓包&#xff0c;最关键的是需要设置好根证书&#xff0c;用户证书在安卓7.0之后就不受信任了&#xff0c;想要对手机app抓包&#xff0c;就需要把用户证书设置为系统证书&#xff08;根证书&#xff09; 注意&#xff0c;想要设置为根证书&#xff0c;你的…

4.4 审计

思维导图&#xff1a; 4.4 审计理解笔记&#xff1a; 1. 审计的重要性&#xff1a; 除了用户身份验证和访问控制&#xff0c;审计是实现数据库安全的关键组成部分。审计是达到高安全标准&#xff08;如TDI/TCSEC的C2级别&#xff09;的必要功能。 2. 审计功能的核心&#xf…

Oracle高速批量速插入数据解决方案

最近做短信群发项目有一个需求,需要客户大批量(十万级)导入数据. 开始是用insert单条数据,10万条数据要20分钟 后来发现可以用insert all 一条sql一次导入500条记录,这样10万条数据只用了1.5分钟,导入速度提高了近来20倍 下面就使用insert all的心得体会记录如下. 使用方法: i…

nrf52832 开发板入手笔记:资料搜集

前言 最近翻箱&#xff0c;发现了两块几年前买的 NRF52832 与 NRF52840 的开发板&#xff0c;打算搭个 BLE 的开发环境 NRF52832 与 NRF51822 之前用过&#xff0c; NRF52840 没有用过&#xff0c;好像是 BLE4 与 BLE5 的区别吧 相关介绍 除了开发板&#xff0c;最重要的还是…