当前位置: 首页 > news >正文

C++ 核心数据结构:Stack 与 Queue 类深度解析

 🌟快来参与讨论💬,点赞👍、收藏⭐、分享📤,共创活力社区。 🌟    


目录

💯前言

💯Stack 类

(一)Stack 类的概念与特点

(二)Stack 类的使用

(三)Stack 类的内部实现(手动实现)

(四)Stack 类的应用场景

💯Queue 类

(一)Queue 类的概念与特点

(二)Queue 类的使用

(三)Queue 类的内部实现(手动实现)

(四)Queue 类的应用场景

💯总结


💯前言

在 C++ 编程领域,数据结构的合理运用是构建高效、可靠程序的关键因素之一。Stack(栈)和 Queue(队列)作为两种基础且重要的数据结构,在众多编程场景中发挥着不可或缺的作用。深入理解它们的原理、特性、操作方式以及内部实现机制,对于提升编程技能、优化程序性能以及解决复杂问题具有深远意义。

接下来,我们将详细解析 Stack 类和 Queue 类,并手动实现它们,以深入探究其内部奥秘。

 


💯Stack 类

(一)Stack 类的概念与特点

  1. 后进先出(LIFO)原则

    Stack 类遵循后进先出的规则,类似于一叠盘子,最后放置的盘子最先被取出。这种特性使得 Stack 在处理具有嵌套结构或需要回溯的问题时表现出色。例如,在函数调用过程中,每次函数调用时的局部变量、参数等信息会依次压入栈中,当函数返回时,这些信息按照后进先出的顺序依次弹出,从而恢复到调用前的状态。

  2. 操作受限性

    Stack 类主要提供了入栈(push)、出栈(pop)、获取栈顶元素(top)、判断栈是否为空(empty)和获取栈的大小(size)等操作。与其他数据结构相比,其操作相对简单且受限,但这也使得它在特定场景下的使用更加高效和便捷。例如,在表达式求值中,我们只需关注当前操作符和操作数,通过栈来存储和处理它们,避免了复杂的遍历和搜索操作。

 

(二)Stack 类的使用

1.包含头文件与创建对象

要使用 Stack 类,需包含<stack>头文件(在我们手动实现的示例中暂不涉及该头文件)。然后可以通过以下方式创建一个 Stack 对象(在手动实现部分会有不同的创建方式):

#include <iostream>
#include <stack>
using namespace std;int main() {stack<int> myStack;// 后续操作...return 0;
}

2.基本操作示例

  • 入栈操作(push):将元素压入栈顶。
myStack.push(10);
myStack.push(20);
myStack.push(30);
  • 出栈操作(pop):弹出栈顶元素。
myStack.pop();
  • 获取栈顶元素(top):返回栈顶元素的值,但不弹出元素。
cout << "栈顶元素: " << myStack.top() << endl;
  • 判断栈是否为空(empty):如果栈为空,返回true,否则返回false
if (myStack.empty()) {cout << "栈为空" << endl;
} else {cout << "栈不为空" << endl;
}
  • 获取栈的大小(size):返回栈中元素的数量。
cout << "栈的大小: " << myStack.size() << endl;

 

 

(三)Stack 类的内部实现(手动实现)

  1. 数据结构选择
    为了手动实现 Stack 类,我们可以选择使用数组或链表来存储元素。这里我们以数组为例进行实现。
  2. 类定义与成员变量
    template<typename T>
    class MyStack {
    private:T* data;int topIndex;int capacity;public:// 构造函数MyStack() {capacity = 10;data = new T[capacity];topIndex = -1;}// 析构函数~MyStack() {delete[] data;}

  3. 入栈操作(push)实现
    void push(const T& value) {if (topIndex == capacity - 1) {// 栈已满,需要扩容capacity *= 2;T* newData = new T[capacity];for (int i = 0; i <= topIndex; i++) {newData[i] = data[i];}delete[] data;data = newData;}topIndex++;data[topIndex] = value;
    }

  4. 出栈操作(pop)实现
    void pop() {if (topIndex >= 0) {topIndex--;}
    }

  5. 获取栈顶元素(top)实现
    T& top() {return data[topIndex];
    }

  6. 判断栈是否为空(empty)实现
    bool empty() const {return topIndex == -1;
    }

  7. 获取栈的大小(size)实现
        int size() const {return topIndex + 1;}
    };

 

(四)Stack 类的应用场景

  1. 函数调用栈
    • 在程序执行过程中,函数的调用和返回顺序通过栈来管理。每当一个函数被调用时,系统会为其分配一个栈帧,用于存储函数的局部变量、参数、返回地址等信息。🚩当函数执行完毕返回时,栈帧被弹出,恢复之前的执行环境。这种机制保证了函数调用的嵌套和递归能够正确执行。
  2. 表达式求值
    • 对于中缀表达式的求值,通常需要将其转换为后缀表达式,然后利用栈来计算。在计算后缀表达式时,操作数依次入栈,遇到运算符时弹出栈顶的操作数进行计算,并将结果再次压入栈中。最终栈顶元素即为表达式的值。
  3. 括号匹配检查
    • 在处理包含括号的表达式或代码结构时,栈可用于检查括号是否匹配。例如,在编译器中,用于检查代码中的括号是否成对出现,🚩通过将左括号入栈,遇到右括号时与栈顶左括号匹配,若匹配成功则弹出栈顶左括号,否则表示括号不匹配。

💯Queue 类

(一)Queue 类的概念与特点

  1. 先进先出(FIFO)原则

    Queue 类遵循先进先出的规则,就像人们在排队等候,最先进入队列的元素最先被取出。这种特性使得 Queue 在处理需要按照顺序处理的任务或数据时非常有用。例如,在任务调度系统中,任务按照提交的顺序依次进入队列,然后按照先进先出的顺序被执行,保证了任务处理的公平性和顺序性。

  2. 操作特性

    Queue 类主要提供了入队(enqueue)、出队(dequeue)、获取队首元素(front)、判断队列是否为空(empty)和获取队列的大小(size)等操作。它专注于在队尾添加元素和在队首删除元素,确保了元素的顺序性。例如,在广度优先搜索算法中,队列用于存储待访问的节点,按照先进先出的顺序依次访问节点,从而实现对图或树的广度优先遍历。

(二)Queue 类的使用

  1. 包含头文件与创建对象
    要使用 Queue 类,需包含<queue>头文件(在手动实现示例中暂不涉及)。然后可以通过以下方式创建一个 Queue 对象(手动实现部分会有不同创建方式):
    #include <iostream>
    #include <queue>
    using namespace std;int main() {queue<int> myQueue;// 后续操作...return 0;
    }

  2. 基本操作示例
  • 入队操作(enqueue):将元素添加到队尾。
    myQueue.push(10);
    myQueue.push(20);
    myQueue.push(30);

  • 出队操作(dequeue):删除队首元素。
    myQueue.pop();

  • 获取队首元素(front):返回队首元素的值,但不删除元素。
    cout << "队首元素: " << myQueue.front() << endl;

  • 判断队列是否为空(empty):如果队列为空,返回true,否则返回false
    if (myQueue.empty()) {cout << "队列为空" << endl;
    } else {cout << "队列不为空" << endl;
    }

  • 获取队列的大小(size):返回队列中元素的数量。
    cout << "队列的大小: " << myQueue.size() << endl;

 

(三)Queue 类的内部实现(手动实现)

  1. 数据结构选择
    同样,我们可以使用数组或链表来手动实现 Queue 类。这里我们以链表为例进行实现。
  2. 类定义与节点结构体
    template<typename T>
    class MyQueue {
    private:struct Node {T data;Node* next;Node(const T& value) : data(value), next(nullptr) {}};Node* frontNode;Node* rearNode;int size;public:// 构造函数MyQueue() : frontNode(nullptr), rearNode(nullptr), size(0) {}// 析构函数~MyQueue() {while (frontNode) {Node* next = frontNode->next;delete frontNode;frontNode = next;}}

  3. 入队操作(enqueue)实现
    void push(const T& value) {Node* newNode = new Node(value);if (rearNode) {rearNode->next = newNode;} else {frontNode = newNode;}rearNode = newNode;size++;
    }

  4. 出队操作(dequeue)实现
    void pop() {if (frontNode) {Node* next = frontNode->next;delete frontNode;frontNode = next;if (!frontNode) {rearNode = nullptr;}size--;}
    }

  5. 获取队首元素(front)实现
    T& front() {return frontNode->data;
    }

  6. 判断队列是否为空(empty)实现
    bool empty() const {return size == 0;
    }

  7. 获取队列的大小(size)实现
        int size() const {return size;}
    };

 

(四)Queue 类的应用场景

  1. 任务调度
    • 在操作系统或任务管理系统中,任务通常按照提交的顺序依次进入队列,然后由处理器按照先进先出的顺序从队列中取出任务进行执行。这种方式确保了任务的公平处理,避免了某些任务长时间等待而得不到执行的情况。
  2. 广度优先搜索(BFS)算法
    • 在对图或树进行广度优先搜索时,队列用于存储待访问的节点。🚩从起始节点开始,将其相邻节点依次入队,然后按照先进先出的顺序取出节点进行访问,并将访问过的节点标记。接着将已访问节点的未访问相邻节点入队,重复这个过程,直到队列为空或找到目标节点。通过队列的先进先出特性,实现了对图或树的层次遍历。
  3. 消息队列
    • 在分布式系统或异步编程中,消息队列用于存储和传递消息。消息按照发送的顺序依次进入队列,接收方按照先进先出的顺序从队列中获取消息进行处理。🚩这种方式保证了消息处理的顺序性,避免了消息乱序导致的问题。

💯总结

✍Stack 类和 Queue 类是 C++ 编程中极为重要的数据结构,它们各自独特的特性和操作方式使其在不同编程场景中发挥着关键作用。通过深入理解它们的概念、使用方法、内部实现机制(尤其是手动实现过程)以及应用场景,我们能够在编程时更加灵活地运用它们解决复杂问题,提高程序效率和可读性。在实际编程中,应根据具体需求选择合适的数据结构,充分发挥其优势,构建高效、健壮的程序。同时,深入了解其底层实现原理有助于在遇到性能瓶颈或特殊需求时对程序进行优化和定制。🍎希望本文能帮助读者更好地掌握 Stack 类和 Queue 类,助力 C++ 编程之旅。


 觉得本文有用?欢迎关注我呀,更多编程干货持续分享哦。

👉【A Charmer】 

相关文章:

C++ 核心数据结构:Stack 与 Queue 类深度解析

&#x1f31f;快来参与讨论&#x1f4ac;&#xff0c;点赞&#x1f44d;、收藏⭐、分享&#x1f4e4;&#xff0c;共创活力社区。 &#x1f31f; 目录 &#x1f4af;前言 &#x1f4af;Stack 类 &#xff08;一&#xff09;Stack 类的概念与特点 &#xff08;二&#x…...

Python枚举类详解:用enum模块高效管理常量数据

《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 在编程中,常量的管理是一个关键环节,合理的管理常量可以提高代码的可读性和可维护性。Python的enum模块提供了一种有效的方式来组织常量数据,通过枚举类(Enum)将相关的常量值集合在一起,使代码更具结…...

企业OA管理系统:Spring Boot技术深度探索

4系统概要设计 4.1概述 本系统采用B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式&#xff0c;是一个适用于Internet环境下的模型结构。只要用户能连上Internet,便可以在任何时间、任何地点使用。系统工作原理图如图4-1所示&#xff1a; 图4-1系统工作原理…...

汽车免拆诊断案例 | 2012款路虎揽胜运动版柴油车加速无力

故障现象  一辆2012款路虎揽胜运动版车&#xff0c;搭载3.0T柴油发动机&#xff08;型号为306DT&#xff09;&#xff0c;累计行驶里程约为10.2万km。车主进厂反映&#xff0c;车辆行驶中加速无力&#xff0c;且发动机故障灯异常点亮。 故障诊断 接车后试车&#xff0c;发动…...

uniapp接入高德地图

下面代码兼容安卓APP和H5 高德地图官网&#xff1a;我的应用 | 高德控制台 &#xff0c;绑定服务选择《Web端(JS API)》 /utils/map.js 需要设置你自己的key和安全密钥 export function myAMap() {return new Promise(function(resolve, reject) {if (typeof window.onLoadM…...

(UI自动化测试)web自动化测试

web自动化测试 UI自动化测试介绍 自动化测试理论&#xff1a; 图片上的文字等等不能做测试&#xff0c;只能发现固定的bug 工具选择及介绍 浏览器驱动&#xff1a;找元素--核心&#xff1a;驱动&#xff08;操作元素&#xff09;--通过代码...

【es6进阶】如何使用Proxy实现自己的观察者模式

观察者模式&#xff08;Observer mode&#xff09;指的是函数自动观察数据对象&#xff0c;一旦对象有变化&#xff0c;函数就会自动执行。这里&#xff0c;我们是使用es6的proxy及reflect来实现这个效果。 实现效果 业务分析 源数据 const object2 {name: "张三"…...

住宅IP怎么在指纹浏览器设置运营矩阵账号

矩阵账号的运营已经成为了许多企业和个人推广策略中的重要一环。通过构建和管理多个社交媒体或电商平台的账号&#xff0c;可以有效地扩大品牌影响力&#xff0c;提高市场覆盖率。然而&#xff0c;随着平台对账号关联的限制越来越严格&#xff0c;如何安全、有效地运营这些矩阵…...

表格数据处理中大语言模型的微调优化策略研究

论文地址 Research on Fine-Tuning Optimization Strategies for Large Language Models in Tabular Data Processing 论文主要内容 这篇论文的主要内容是研究大型语言模型&#xff08;LLMs&#xff09;在处理表格数据时的微调优化策略。具体来说&#xff0c;论文探讨了以下…...

CentOS7 如何查看kafka topic中的数据

1. 确保 Kafka 服务运行 先检查 Kafka 和 Zookeeper 是否正在运行&#xff1a; systemctl status kafka systemctl status zookeeper 如果没有启动&#xff0c;先启动服务&#xff1a; systemctl start zookeeper systemctl start kafka 2. 进入 Kafka 安装目录 通常 …...

VRRP实现出口网关设备冗余备份

VRRP虚拟路由冗余 vrrp实现设备主备备份 Tips&#xff1a; VRRP能够在不改变组网的情况下&#xff0c;将多台路由器虚拟成一个虚拟路由器&#xff0c;通过配置虚拟路由器的IP地址为默认网关&#xff0c;实现网关的备份。协议版本: VRRPV2 (常用)和VRRPV3:VRRPV2仅适用于IPv4…...

超详细:Redis分布式锁

如何基于 Redis 实现一个最简易的分布式锁&#xff1f; 不论是本地锁还是分布式锁&#xff0c;核心都在于“互斥”。 在 Redis 中&#xff0c; SETNX 命令是可以帮助我们实现互斥。SETNX 即 SET if Not eXists (对应 Java 中的 setIfAbsent 方法)&#xff0c;如果 key 不存在…...

Vue与React的Suspense组件对比

在Vue和React中都内置了Suspense组件&#xff0c;该组件用于处理异步组件加载。当Suspense包裹的实际组件内容尚未加载完成时会先展示后备内容&#xff0c;等待组件内容加载完成后再切换成实际组件内容。这可以显著提升用户体验&#xff0c;适用于大数据加载、组件懒加载等场景…...

Spring框架深度剖析:特性、安全与优化

文章目录 Spring框架简介主要特性1. 依赖注入&#xff08;Dependency Injection, DI&#xff09;2. 面向切面编程&#xff08;Aspect-Oriented Programming, AOP&#xff09;3. 声明式事务管理4. 强大的MVC框架5. 集成测试支持6. 多种数据访问技术的支持 安全性1. 认证&#xf…...

硬盘文件误删:全面解析、恢复方案与预防策略

一、硬盘文件误删现象概述 在日常使用电脑的过程中&#xff0c;硬盘文件误删是许多用户都曾遇到过的问题。这种意外的数据丢失&#xff0c;不仅可能让我们辛苦编辑的文档、珍贵的照片和视频等瞬间消失&#xff0c;还可能对工作和生活造成重大影响。硬盘文件误删&#xff0c;如…...

tcpdump抓包 wireShark

TCPdump抓包工具介绍 TCPdump&#xff0c;全称dump the traffic on anetwork&#xff0c;是一个运行在linux平台可以根据使用者需求对网络上传输的数据包进行捕获的抓包工具。 tcpdump可以支持的功能: 1、在Linux平台将网络中传输的数据包全部捕获过来进行分析 2、支持网络层…...

Android system_server进程

目录 一、system_server进程介绍 二、system_server进程启动流程 2.1 startBootstrapServices 2.2 startCoreServices 2.3 startOtherServices 2.4 startApexServices 三、如何使用系统服务 3.1 app进程调用系统服务 3.2 native进程调用系统服务 3.3 system_server进…...

Vue3+element-plus 实现中英文切换(Vue-i18n组件的使用)

1、前言 在 Vue 3 项目中结合 vue-i18n 和 Element Plus 实现中英文切换是一个常见的需求。下面是一个详细的步骤指南&#xff0c;帮助你完成这个任务。 安装引入 1. 安装依赖 首先&#xff0c;你需要安装 vue-i18n 和 Element Plus。 npm install vue-i18nnext element-p…...

python实现猜数字游戏( 可视化easygui窗口版本 )

1.先上源代码 import random import easygui as egdef guess_ordinary():answer random.randint(0, 11)user_answer int(eg.enterbox(msg "请在0-10中选择一个整数: ", title "猜数字"))if user_answer answer:eg.msgbox(msg "恭喜你&#xff…...

自由学习记录(23)

Lua的学习 table.concat(tb,";") 如果表里带表&#xff0c;则不能拼接&#xff0c;表里带nil也不能&#xff0c;都会报错 true和false也不可以&#xff0c;数字和字符串可以 if要和一个end配对&#xff0c;所以 if a>b then return true end end 两个end …...

Python开发者首次使用Taotoken接入大模型API的完整步骤指南

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 Python开发者首次使用Taotoken接入大模型API的完整步骤指南 对于Python开发者而言&#xff0c;接入大模型API进行应用开发已成为一…...

户外实用|艾迪欧 R6000 测评 —— 户外 / 自驾 / 露营的通讯好搭档

户外出行&#xff0c;通讯工具的核心是稳定、清晰、耐用、续航久、功能全。艾迪欧 R6000 作为一款兼顾专业与户外的 DMR 对讲机&#xff0c;全频段覆盖、双模通讯、自定义功能、长续航&#xff0c;完美适配自驾、露营、登山、越野等户外场景&#xff0c;是户外爱好者的靠谱通讯…...

Burp Suite深度解析:从流量抓包到业务逻辑漏洞挖掘

1. 这不是“学个插件”——Burp Suite 是渗透测试的呼吸系统 很多人第一次听说 Burp Suite&#xff0c;是在某篇“三步拿下登录框”的速成教程里&#xff1a;装好Java、拖进浏览器代理、点几下Repeater就弹出密码明文。结果真去测一个中型SaaS后台&#xff0c;不到十分钟就卡在…...

科华UPS电源全品类汇总:选型与场景适配指南

科华UPS电源作为国内智慧电能领域的主流产品&#xff0c;覆盖家用、办公、机房、工业等全场景&#xff0c;产品系列丰富、规格齐全&#xff0c;但多数用户在选型时&#xff0c;常因分不清系列差异、功率适配、架构类型而踩坑。本文系统汇总科华UPS电源的核心分类、主流系列、核…...

广州因特智能:AI视觉软硬结合,打破半导体检测装备“卡脖子”困境

【导语&#xff1a;广州因特智能科技孵化于西安电子科技大学广州研究院&#xff0c;专注用AI视觉技术解决工业场景的“卡脖子”检测难题&#xff0c;为半导体、光通信、新能源三大领域提供高端检测装备。】校地合作孵化&#xff0c;构建完整能力体系广州因特智能科技由西安电子…...

电信运营商每月处理海量工单,如何不再出错?基于AI Agent的端到端自动化解决方案

在2026年的电信行业&#xff0c;海量工单处理已不再仅仅是效率问题&#xff0c;而是合规与生存的底线。随着2026年5月20日《电信和互联网服务 基础电信企业网上营业厅服务规范》国家标准的正式实施&#xff0c;监管层对“信息透明、流程闭环、计费精准”的要求达到了前所未有的…...

如何快速解锁艾尔登法环帧率限制:终极性能优化指南

如何快速解锁艾尔登法环帧率限制&#xff1a;终极性能优化指南 【免费下载链接】EldenRingFpsUnlockAndMore A small utility to remove frame rate limit, change FOV, add widescreen support and more for Elden Ring 项目地址: https://gitcode.com/gh_mirrors/el/EldenR…...

Windows Cleaner:终极免费系统清理工具,彻底解决C盘空间不足问题

Windows Cleaner&#xff1a;终极免费系统清理工具&#xff0c;彻底解决C盘空间不足问题 【免费下载链接】WindowsCleaner Windows Cleaner——专治C盘爆红及各种不服&#xff01; 项目地址: https://gitcode.com/gh_mirrors/wi/WindowsCleaner 你是否经常遇到C盘爆红、…...

DAIR-V2X-V数据集深度评测:与KITTI、nuScenes比,它到底强在哪?

DAIR-V2X-V数据集深度评测&#xff1a;与KITTI、nuScenes比&#xff0c;它到底强在哪&#xff1f; 当技术团队着手开发面向中国道路的自动驾驶系统时&#xff0c;数据集的选择往往成为第一个关键决策点。过去十年间&#xff0c;KITTI和nuScenes等国际数据集一直是行业标杆&…...

LoRa物联网与动态基线算法在养殖体温监测中的实战应用

1. 项目概述&#xff1a;为什么我们需要一个智能体温监测系统&#xff1f;在规模化养殖场里干了十几年&#xff0c;我见过太多因为体温异常没被及时发现而导致的损失。一头育肥猪突然不吃食&#xff0c;等饲养员第二天巡栏发现时&#xff0c;可能已经高烧好几天&#xff0c;继发…...