数据结构与算法:栈与队列的高级应用

news2024/11/25 12:50:29

目录

3.1 栈的高级用法

3.2 队列的深度应用

3.3 栈与队列的综合应用

总结


数据结构与算法:栈与队列的高级应用

栈和队列是两种重要的线性数据结构,它们在计算机科学和工程的许多领域都有广泛的应用。从函数调用到表达式求值,再到任务调度系统,栈和队列无处不在。通过深入理解栈和队列的操作、内存管理及其高级应用,我们可以更好地使用这些基础结构来解决复杂的问题。本章将深入探讨栈与队列的高级应用。

3.1 栈的高级用法

栈是一种“后进先出”(LIFO,Last In First Out)的数据结构,具有非常明确的使用场景。栈在函数调用和递归处理、表达式求值、语法解析等方面有着广泛的应用。

栈帧在函数调用与递归中的应用:在程序执行过程中,每次函数调用都会创建一个栈帧,并将其压入调用栈中。栈帧中保存了函数的局部变量、返回地址等信息。递归调用通过重复利用栈来管理函数调用顺序和返回结果。

代码示例:递归函数的栈帧示意

#include <stdio.h>

int factorial(int n) {
    if (n == 0) {
        return 1;
    } else {
        return n * factorial(n - 1);
    }
}

int main() {
    int num = 5;
    printf("%d 的阶乘是 %d\n", num, factorial(num));
    return 0;
}

在这个代码示例中,每次调用 factorial() 时,都会在调用栈上创建一个新的栈帧,直到 n 减到 0 为止。在递归的返回阶段,栈帧按相反的顺序出栈,计算并返回结果。

栈在表达式求值与语法解析中的应用:栈被广泛用于表达式求值(例如中缀表达式转后缀表达式)以及编译器中的语法解析。通过将操作符压入栈,可以处理不同优先级的运算符,并确保表达式求值的正确性。

代码示例:中缀表达式转后缀表达式

#include <stdio.h>
#include <ctype.h>

#define MAX 100
char stack[MAX];
int top = -1;

void push(char c) {
    stack[++top] = c;
}

char pop() {
    return stack[top--];
}

int precedence(char op) {
    if (op == '+' || op == '-') {
        return 1;
    } else if (op == '*' || op == '/') {
        return 2;
    }
    return 0;
}

void infixToPostfix(char* exp) {
    char* p = exp;
    while (*p != '\0') {
        if (isdigit(*p)) {
            printf("%c ", *p);
        } else if (*p == '(') {
            push(*p);
        } else if (*p == ')') {
            while (top != -1 && stack[top] != '(') {
                printf("%c ", pop());
            }
            pop();
        } else {
            while (top != -1 && precedence(stack[top]) >= precedence(*p)) {
                printf("%c ", pop());
            }
            push(*p);
        }
        p++;
    }
    while (top != -1) {
        printf("%c ", pop());
    }
    printf("\n");
}

int main() {
    char expression[] = "3+(2*4)-5";
    printf("后缀表达式: ");
    infixToPostfix(expression);
    return 0;
}

在这个示例中,栈被用来存储操作符,确保运算符按正确的优先级顺序输出,从而完成中缀表达式到后缀表达式的转换。

双栈实现最小栈问题:最小栈是一种特殊的栈,它在常数时间内返回栈中最小的元素。可以通过两个栈来实现,一个用于存储数据,另一个用于存储当前最小值。

代码示例:最小栈的实现

#include <stdio.h>
#include <stdlib.h>

#define MAX 100
int stack[MAX];
int minStack[MAX];
int top = -1;
int minTop = -1;

void push(int value) {
    stack[++top] = value;
    if (minTop == -1 || value <= minStack[minTop]) {
        minStack[++minTop] = value;
    }
}

void pop() {
    if (top == -1) {
        return;
    }
    if (stack[top] == minStack[minTop]) {
        minTop--;
    }
    top--;
}

int getMin() {
    return minStack[minTop];
}

int main() {
    push(10);
    push(20);
    push(5);
    push(15);
    printf("当前最小值: %d\n", getMin());
    pop();
    printf("当前最小值: %d\n", getMin());
    return 0;
}

通过维护一个辅助栈来存储最小值,可以在常数时间内获取栈的最小元素,从而实现高效的最小栈操作。

栈在图的遍历与路径记录中的应用:在图的深度优先遍历(DFS)中,栈被用来追踪访问过的节点,确保每个节点都被访问一次并记录路径。

3.2 队列的深度应用

队列是一种“先进先出”(FIFO,First In First Out)的数据结构,它在很多场景下都具有不可替代的作用。队列在任务调度、广度优先搜索等领域有着广泛的应用。

循环队列与环形缓冲区设计:循环队列是一种特殊的队列,它通过将队尾和队首连接形成一个环状,使得队列可以高效利用内存空间,特别适合于资源有限的系统,如嵌入式系统中的数据缓冲区管理。

代码示例:循环队列的实现

#include <stdio.h>
#define MAX 5

int queue[MAX];
int front = -1;
int rear = -1;

void enqueue(int value) {
    if ((rear + 1) % MAX == front) {
        printf("队列已满\n");
    } else {
        if (front == -1) front = 0;
        rear = (rear + 1) % MAX;
        queue[rear] = value;
    }
}

void dequeue() {
    if (front == -1) {
        printf("队列为空\n");
    } else {
        printf("移除元素: %d\n", queue[front]);
        if (front == rear) {
            front = rear = -1;
        } else {
            front = (front + 1) % MAX;
        }
    }
}

int main() {
    enqueue(10);
    enqueue(20);
    enqueue(30);
    enqueue(40);
    enqueue(50);
    dequeue();
    enqueue(60);
    dequeue();
    return 0;
}

在这个代码示例中,循环队列通过将数组的末端和开头相连,实现了空间的循环利用,使得队列可以在有限的内存中实现高效的插入和删除操作。

优先队列与双端队列(Deque)的实现:优先队列是一种特殊的队列,其中每个元素都有一个优先级,出队时优先级最高的元素优先被移除。优先队列在调度算法中具有重要作用,例如操作系统的任务调度。

队列在操作系统中的调度算法应用:队列广泛用于操作系统中的任务管理和调度。例如,打印队列、CPU任务调度队列等。通过合理使用优先队列,操作系统可以保证高优先级任务的及时响应,从而提高系统的效率和用户体验。

3.3 栈与队列的综合应用

应用实例分析:浏览器历史记录与任务调度系统:浏览器历史记录通常使用栈来存储访问的页面,用户点击“返回”按钮时会从栈中弹出上一个页面。同时,队列在任务调度系统中用于管理各个任务的执行顺序,保证先进先出的调度策略。

栈与队列在实际项目中的设计模式:栈和队列在实际项目中往往可以结合使用。例如,深度优先搜索使用栈来追踪节点,而广度优先搜索则使用队列。理解如何在复杂系统中结合使用这些数据结构,有助于构建更高效的算法。

总结

本章介绍了栈和队列的高级应用,包括它们在递归、表达式求值、任务调度、图遍历等方面的重要作用。栈的LIFO特性使得它在函数调用管理、表达式求值等场景中不可替代,而队列的FIFO特性则使其在任务调度和广度优先搜索中占据核心地位。理解栈与队列的高级用法,能够帮助我们设计出更高效、灵活的数据处理系统。

在下一章中,我们将讨论递归、分治与回溯等算法范式,它们与栈有着密不可分的关系,并且在解决复杂问题时表现出了卓越的能力。

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

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

相关文章

c#的opcua客户端源码,支持用户名密码

在工作中遇到需要采集西门子机床的opcua和kepServer的opcua&#xff0c;找了一些网上的demo都不能都连接成功&#xff0c;好不容易找到一个两个都支持的c#opcua客户端源码&#xff0c;分享给大家。 软件界面如下 连接kepserver成功的界面 连接西门子opcua的界面 c#源码链接如下…

开关电源调制模式和工作模式

开关电源调制模式和工作模式 ‌‌开关电源定义开关电源分类‌单管DC/DC和、双管DC/DC和四管DC/DC的主要区别正激和反激 DCDCBUCK原理BOOST原理BUCK-BOOST原理异步整流和异步整流同步整流异步整流同步和异步整流区别同步和异步整流优缺点 DCDC调制模式PWM&#xff08;Pulse Widt…

C++ | Leetcode C++题解之第475题供暖器

题目&#xff1a; 题解&#xff1a; class Solution { public:int findRadius(vector<int>& houses, vector<int>& heaters) {sort(houses.begin(), houses.end());sort(heaters.begin(), heaters.end());int ans 0;for (int i 0, j 0; i < houses.…

轻松掌握TCP与UDP核心机制

White graces&#xff1a;个人主页 &#x1f649;专栏推荐:Java入门知识&#x1f649; &#x1f649; 内容推荐:网络编程TCP&#x1f649; &#x1f439;今日诗词:Best wishes&#x1f439; ⛳️点赞 ☀️收藏⭐️关注&#x1f4ac;卑微小博主&#x1f64f; ⛳️点赞 ☀️收…

相机曝光的两种模式

相机的曝光模式 相机帧率和曝光时间的关系 相机的图像采集包括曝光(Exposure)和读出(Readout)两部分 曝光又分为非重叠(non-overlapped)曝光和重叠(overlapped)曝光两种 在非重叠(“non-overlapped”)模式中&#xff0c;每个图像采集的周期中&#xff0c;相机在下一个图像采集…

萝卜快跑:迈向全球,挑战与机遇并存

萝卜快跑&#xff1a;迈向全球&#xff0c;挑战与机遇并存 引言 萝卜快跑的崛起 萝卜快跑的优势 萝卜快跑面临的挑战 未来展望 引言 在当今科技飞速发展的时代&#xff0c;自动驾驶技术成为了全球瞩目的焦点。众多科技巨头纷纷投入大量资源&#xff0c;试图在这个新兴领域…

文件完整性监控:如何提高企业的数据安全性

企业网络庞大而复杂&#xff0c;需要处理大量关键业务数据&#xff0c;这些敏感文件在企业网络中不断传输&#xff0c;并由多个用户和实体存储、共享和访问。FIM 工具或具有 FIM 功能的 SIEM 解决方案使企业能够跟踪未经授权的文件更改、对敏感信息的恶意访问、数据篡改尝试和内…

FreeRTOS——空闲任务和钩子函数介绍

空闲任务 在前面的学习中我们提到&#xff0c;空闲任务会负责释放一些被删除任务的内存&#xff0c;在FreeRTOS中&#xff0c;用户分配的内存通常也是在空闲任务中释放的。空闲任务是一个特殊的任务&#xff0c;当没有其他任务需要运行时&#xff0c;系统将会调度空闲任务来执行…

硬盘格式化后能恢复数据吗?好用4款工具集锦

嘿&#xff0c;硬盘格式化后能恢复数据吗&#xff1f;咱们现在的生活&#xff0c;数据可是宝贝&#xff0c;这大家都清楚。学习用的资料、工作的文件&#xff0c;还有那些宝贵的照片、视频&#xff0c;统统都存硬盘里。万一硬盘不小心被格式化了&#xff0c;那感觉就像所有东西…

【GUI】使用 PySide6 开发图片左右切换软件

使用 PySide6 开发图片左右切换软件 前言 在现代软件开发中&#xff0c;使用 Python 开发跨平台的 GUI 应用程序变得非常普遍。今天&#xff0c;我们将使用 PySide6 来开发一个简单的图片浏览器&#xff0c;它可以实现图片左右切换的功能&#xff0c;并自适应按钮布局。本教程…

闭着眼学机器学习——朴素贝叶斯分类

引言&#xff1a; 在正文开始之前&#xff0c;首先给大家介绍一个不错的人工智能学习教程&#xff1a;https://www.captainbed.cn/bbs。其中包含了机器学习、深度学习、强化学习等系列教程&#xff0c;感兴趣的读者可以自行查阅。 1. 算法介绍 朴素贝叶斯是一种基于贝叶斯定理…

c++应用网络编程之十一Linux下的epoll模式基础

一、epoll模式 在前面分析了select和poll两种IO多路复用的模式&#xff0c;但总体给人的感觉有一种力不从心的感觉。尤其是刚刚接触底层网络开发的程序员&#xff0c;被很多双十一千万并发&#xff0c;游戏百万并发等等已经给唬的一楞一楞的。一听说只支持一两千个并发&#x…

YOLOv9分割改进 ,YOLOv9分割改进主干网络为华为EfficientNet,助力涨点

YOLOv9 分割改进前训练结果: YOLOv9 分割改进后训练结果: 摘要 卷积神经网络(ConvNets)通常在固定的资源预算下开发,然后在有更多资源时进行扩展以提高准确性。在本文中,我们系统地研究了模型扩展,并发现仔细平衡网络深度、宽度和分辨率可以带来更好的性能。基于这一…

【Python库安装】Python环境安装wrf-python库

【Python库安装】Python环境安装wrf-python库 wrf-python库概述Python中安装wrf-python库方式1&#xff1a;使用pip安装方式2&#xff1a;离线安装&#xff0c;使用whl文件安装另&#xff1a;报错 方式3&#xff1a;使用conda安装wrf-python另&#xff1a;报错 参考 wrf-python…

教育培训系统小程序的设计

教师账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;课后习题测试管理&#xff0c;观看进度管理&#xff0c;论坛管理&#xff0c;网课信息管理&#xff0c;公告信息管理&#xff0c;学生管理&#xff0c;试卷管理&#xff0c;测试管理 微信端账号功能包括…

RK3568学习之Nginx移植+RTMP推流

1.下载 Nginx 源码 进入到 Ubuntu 系统的某个目录下&#xff0c;下载 Nginx 源码&#xff1a; wget http://nginx.org/download/nginx-1.20.0.tar.gz这里我们下载的是 1.20 版本&#xff0c;这是比较新的版本了。下载完成之后将得到一个名为 nginx-1.20.0.tar.gz的压缩包文件…

嵌入式中数据库sqlit3基本使用方法与现象

大家好,今天主要给大家分享一下,数据库的使用方法,观察对应的效果。 第一:数据库sqlit3基本安装方法 sqlite3 安装 使用 Ubuntu # 安装软件 sudo apt-get install sqlite3# 查看版本 sqlite3 -version# 安装编译工具包 sudo apt-get install sqlite3-dev# 安装可视化工具…

为何2024年诺贝尔物理学奖颁发给了机器学习与神经网络领域的研究者?

近日&#xff0c;2024年诺贝尔物理学奖颁发给了机器学习与神经网络领域的研究者&#xff0c;这是历史上首次出现这样的情况。这项奖项原本只授予对自然现象和物质的物理学研究作出重大贡献的科学家&#xff0c;如今却将全球范围内对机器学习和神经网络的研究和开发作为了一种能…

html css js 生成随机颜色

起因&#xff0c; 目的: 整理文件&#xff0c;发现之前写的一个小工具。 效果图 点击按钮会生成新的格子。 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta name"viewport" content"wi…

3.计算机网络_端口号

端口号的由来 运输层的作用&#xff1a; 在计算机网络中&#xff0c;运输层处在用户功能的最底层、通信部分的最高层的位置&#xff0c;也就是说运输层是用户数据和实际网络通信的桥梁。因此运输层屏蔽了网络的实现部分&#xff0c;以协议的方式向用户层提供了接口&#xff…