[Data structure]栈

news2024/11/18 18:30:47

⭐作者介绍:大二本科网络工程专业在读,持续学习Java,努力输出优质文章
⭐作者主页:@逐梦苍穹
⭐所属专栏:数据结构。数据结构专栏主要是在讲解原理的基础上拿Java实现,有时候有C/C++代码。
⭐如果觉得文章写的不错,欢迎点个关注一键三连😉有写的不好的地方也欢迎指正,一同进步😁

目录

  • 1、简介
  • 2、栈的特点
  • 3、应用场景
  • 4、代码实现
    • 4.1、思路分析
    • 4.2、Stack
      • Java
      • C++

1、简介

  栈(Stack)是一种常见的数据结构,它遵循"先进后出"(Last-In-First-Out,LIFO)的原则。栈的操作主要包括入栈(Push)和出栈(Pop)两种基本操作,其中入栈将元素放入栈的顶部,而出栈则从栈的顶部移除元素。
  栈可以想象成一叠盘子,每当放入一个新的盘子时,它就被放在上面,而当需要取出盘子时,也是从上面开始取。因此,最后放入的盘子会最先被取出。

2、栈的特点

  1. LIFO原则:栈遵循"后进先出"的原则,最后放入的元素会首先被访问和移除。
  2. 限定访问位置:栈只允许在栈顶进行插入和删除操作,无法直接访问或修改栈底的元素。
  3. 时间复杂度:入栈和出栈操作的时间复杂度为O(1),即常数时间。

栈的实现可以基于数组或链表。使用数组实现的栈称为顺序栈(Sequential Stack),使用链表实现的栈称为链式栈(Linked Stack)。

以下是栈的基本操作:

  1. Push(入栈):将元素添加到栈的顶部。如果栈已满,可能会发生栈上溢(Stack Overflow)的错误。
  2. Pop(出栈):从栈的顶部移除一个元素,并返回该元素的值。如果栈为空,可能会发生栈下溢(Stack Underflow)的错误。
  3. Top/Peek(查看栈顶元素):返回栈顶元素的值,但不移除它。
  4. isEmpty(判断栈是否为空):检查栈是否为空,如果为空则返回True,否则返回False。
  5. isFull(判断栈是否为满):检查栈是否为满,如果为满则返回True,否则返回False。

3、应用场景

栈在计算机科学和软件工程中有广泛的应用,例如:

  1. 函数调用栈:用于跟踪函数的调用顺序和局部变量的存储。
  2. 表达式求值:使用栈来处理中缀表达式转换为后缀表达式,并计算表达式的值。
  3. 撤销操作:在文本编辑器、图形操作等应用中,使用栈来存储操作历史,以便撤销先前的操作。
  4. 浏览器历史记录:浏览器使用栈来存储访问过的网页,使得用户可以通过后退按钮按照访问的顺序导航。
  5. 深度优先搜索(DFS):在图算法中,栈用于实现深度优先搜索算法的追踪回溯。

栈是一种简单而强大的数据结构,可以通过合理应用栈来解决各种问题,同时也为其他复杂的数据结构和算法提供了基础支持。

4、代码实现

4.1、思路分析

  1. Push(压栈):将元素添加到栈的顶部。top++;
  2. Pop(弹栈):从栈的顶部移除一个元素,并返回该元素的值。top–;
  3. top(栈顶指针):初始值为-1。
  4. isEmpty(判断栈是否为空):检查栈是否为空,如果为空则返回True,否则返回False。
  5. isFull(判断栈是否为满):检查栈是否为满,如果为满则返回True,否则返回False。
      在这里插入图片描述

4.2、Stack

Java

在这里插入图片描述

package stack;

/**
 * @author 逐梦苍穹
 * @date 2023/5/25 20:34
 */
public class Stack<T> {
    private final int maxSize;
    private final Object[] stack;
    private int top = -1;

    public Stack(int maxSize) {
        this.maxSize = maxSize;
        this.stack = new Object[this.maxSize];
    }

    /**
     * 栈满
     */
    public boolean isFull(){
        return (top == maxSize - 1);
    }

    /**
     * 栈空
     */
    public boolean isEmpty(){
        return (top == -1);
    }

    /**
     * 压栈
     */
    public void push(T value){
        if (isFull()){
            System.out.println("栈满");
        }
        top++;
        stack[top] = value;
    }

    /**
     * 弹栈
     */
    public Object pop(){
        if (isEmpty()){
            System.out.println("栈空");
        }
        Object value = stack[top];
        stack[top] = null;
        top--;
        return value;
    }

    /**
     * 显示栈的内容
     */
    public void showStack(){
        //从栈顶遍历,但是不是弹栈
        if(!isEmpty()) {
            for(int i = top; i >= 0 ; i--) {
                System.out.printf("stack[%d]=%d\n", i, stack[i]);
            }
        }else {
            System.out.println("栈空");
        }
    }
}

C++

#include <vector>
#include <stdexcept>

template <typename T>
class Stack {
private:
    std::vector<T> stack; // 用vector作为底层存储结构

public:
    // 构造函数
    Stack() : stack(std::vector<T>()) {
    }

    // 入栈操作
    void push(T item) {
        stack.push_back(item);
    }

    // 出栈操作
    T pop() {
        if (isEmpty()) {
            throw std::out_of_range("Stack is empty");
        }
        T item = stack.back();
        stack.pop_back();
        return item;
    }

    // 查看栈顶元素
    T peek() {
        if (isEmpty()) {
            throw std::out_of_range("Stack is empty");
        }
        return stack.back();
    }

    // 判断栈是否为空
    bool isEmpty() {
        return stack.empty();
    }

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/569660.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

一文学会随机森林在sklearn中的实现

1 概述 集成学习(ensemble learning)是时下非常流行的机器学习算法,它本身不是一个单独的机器学习算法,而是通 过在数据上构建多个模型,集成所有模型的建模结果。基本上所有的机器学习领域都可以看到集成学习的身影,在 现实中集成学习也有相当大的作用,它可以用来做市场…

8、URP自定义屏幕后处理

回到目录 大家好&#xff0c;我是阿赵。这次来说一下URP渲染管线里面怎样使用后处理效果&#xff0c;还有怎样去自定义后处理效果。 一、使用URP自带的后处理效果 要使用URP自带的后处理效果&#xff0c;方法很简单&#xff0c;和Unity内置渲染管线的PostProcessing后处理很…

深度学习实战——不同方式的模型部署(CNN、Yolo)

忆如完整项目/代码详见github&#xff1a;https://github.com/yiru1225&#xff08;转载标明出处 勿白嫖 star for projects thanks&#xff09; 目录 系列文章目录 一、实验综述 1.实验工具及及内容 2.实验数据 3.实验目标 4.实验步骤 二、ML/DL任务综述与模型部署知识…

python:容器:列表——常用操作

列表.append(元素)向列表中追加一个元素列表.extend(容器)将数据容器的内容依次取出&#xff0c;追加到列表尾部列表.insert(下标,元素)在指定下标处&#xff0c;插入指定的元素del 列表[下标]删除列表指定的下标元素列表.pop(下标)删除列表指定的下标元素列表.remove(元素)从前…

【LeetCode热题100】打卡第3天:无重复字符的最长子串

文章目录 无重复字符的最长子串⛅前言&#x1f512;题目&#x1f511;题解 无重复字符的最长子串 ⛅前言 大家好&#xff0c;我是知识汲取者&#xff0c;欢迎来到我的LeetCode热题100刷题专栏&#xff01; 精选 100 道力扣&#xff08;LeetCode&#xff09;上最热门的题目&…

【高数+复变函数】傅里叶变换的性质

文章目录 【高数复变函数】傅里叶变换的性质一、常见性质1.1 线性性质1.2 位移性质1.3 微分性质1.4 积分性质1.5 乘积定理1.6 能量积分 二、卷积2.1 卷积运算2.2 运算应用2.3 卷积定理 三、相关函数 【高数复变函数】傅里叶变换的性质 上一节&#xff1a;【高数复变函数】傅里…

2.labelme转yolo格式和MS COCO格式

2.labelme转yolo格式和MS COCO格式 2.1 数据集划分 import os import random import shutildef moveimg(fileDir, tarDir):pathDir os.listdir(fileDir) # 取图片的原始路径filenumber len(pathDir)rate 0.01 # 自定义抽取图片的比例&#xff0c;比方说100张抽10张&…

Verilog 基础知识

文章目录 Verilog 简单介绍数据类型介绍变量运算符及表达式非阻塞赋值和阻塞赋值条件语句循环语句顺序块和并行块结构说明语句assign 语句打印信息宏定义 Verilog 简单介绍 Verilog HDL是硬件描述语言的一种&#xff0c;用于数字电子系统设计。该语言允许设计者进行各种级别的…

Verilog | FIFO简单实现

FIFO( First Input First Output)简单说就是指先进先出&#xff0c;也是缓存机制的一种&#xff0c;下面是我总结的 FIFO 的三大用途&#xff1a; 1)提高传输效率&#xff0c;增加 DDR 带宽的利用率。比如我们有 4 路视频数据缓存到 DDR 中去&#xff0c;比较笨的方法是&#x…

SpringBoot毕业设计40个项目分享(源码+论文)(一)

文章目录 前言 课题1 : 基于SSM与VUE的旅游信息分享管理平台 <br /> 课题2&#xff1a;基于SSMVUE的中医商城管理系统 <br /> 课题3 : 基于SSM的汽车租赁系统<br /> 课题4 : 基于SSM与VUE的汉服销售论坛系统 <br /> 课题5 : 基于SSM的疫情校园师生登记…

java boot项目配置方式优先级

java boot项目认识一下三种格式的配置文件 中 我们说的 boot项目中支持三种配置文件格式 分别是 application.properties application.yml application.yaml 其中 我们也说推荐大家用application.yml格式的 那么 问题就来了 如果三个文件都存在于 resources目录下 系统会听谁的…

继电器相关知识

这个就是继电器&#xff0c;左边有三个接口&#xff0c;VCC(3.3v),GND,IO右面有COM,NO,NC。左侧的IO口如果接受到低电平&#xff0c;继电器内部线圈就会工作&#xff0c;然后供电&#xff0c;开关由NC端闭合到NO端&#xff0c;NO开始闭合&#xff0c;例如&#xff1a;可以将喇叭…

Real-Time C++ 嵌入式C++ 程序设计(三)

翻译自 Real-Time C Efficient Object-Oriented and Template Microcontroller Programming 4th Edition - Kormanyos, Christopher&#xff0c;这书涉及了从C11 到C20 的内容&#xff0c;主要介绍使用C 的模板、面向对象等特性设计嵌入式程序。书里的示例代码都是公开的&#…

ChatGPT报错:Sorry, you have been blocked解决方法

今天打开ChatGPT&#xff0c;发现再一次报错了&#xff01; 又一次出问题了。。。。。。。无语&#xff01; 原因分析 1、内容过滤&#xff1a;某些平台或网站可能使用内容过滤系统&#xff0c;该系统可能将AlI语言模型视为潜在的风险&#xff0c;从而对其进行封锁或限制。这…

传染病学模型 | Matlab实现基于SIS传染病模型模拟城市内人口的互相感染及城市人口流动所造成的传染

文章目录 效果一览基本描述模型介绍程序设计参考资料效果一览 基本描述 传染病学模型 | Matlab实现基于SIS传染病模型模拟城市内人口的互相感染及城市人口流动所造成的传染 模型介绍 SIS模型是一种基本的传染病学模型,用于描述一个人群中某种传染病的传播情况。SIS模型假设每个…

jsonschema networknt json-schema-validator 高级能力 自定义类校验

入参校验产品化 schema_个人渣记录仅为自己搜索用的博客-CSDN博客 自定义的string format可以使用. 详见 fpe的 addFormatValidator ajv 的 addFormat能力 借鉴自chatgpt , 谷歌了半天没答案. Q: "networknt JsonSchemaFactory Keyword " A: 如下 <dependenc…

windows下cplex20.1.0的下载、安装、IDE编程及相关问题解决

其他文章&#xff1a; 通过0-1背包问题看穷举法、贪心算法、启发式算法&#xff08;JAVA) 模拟退火(SA)算法实例介绍&#xff08;JAVA) 遗传算法&#xff08;GA&#xff09;实例介绍&#xff08;JAVA) CPLEX求解器入门案例 java集成Cplex&#xff1a;Cplex下载、IDEA环境搭…

css面试复习

目录 css常用网址: css三种书写样式 css属性 color(如字体颜色) text-decoration(如下划线) text-align(文字对齐) 字体属性 font-size font-family(字体名称) font-weight(字体粗细) font-style(斜体) line-height font缩写属性 css常见选择器 通用选择器 简单…

小黑子—MySQL数据库:第一章 -基础篇

MySQL数据库入门1.0 MySQL基础篇1. MySQL概述1.1 MySQL相关概念1.2 MySQL的安装及启动1.3 数据模型 2. SQL2.1 SQL的通用语法2.2 SQL语句的分类2.3 DDL语句2.3.1 DDL - 数据库操作2.3.2 DDL - 表操作 - 查询2.3.3 DDL - 表操作 - 创建2.3.4 DDL - 表操作 - 数据类型2.3.5 DDL -…

搭建stm32电机控制代码框架(三)——Stm32CubeMx配置ADC采样

电机控制另一个关键的模块就是ADC采样&#xff0c;这个模块配置的好坏决定了采样电流和电压的精准度&#xff0c;因此有必要对其进行深入学习。 简介&#xff1a; STM32 在片上集成的ADC 外设非常强大。STM32F103xC、STM32F103xD 和STM32F103xE增强型产品内嵌3个12位的ADC&am…