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

括号匹配问题--栈

括号匹配问题

  • 栈的应用
    • 代码概览
    • 栈操作函数详解
      • 1.初始化栈(stackInit)
      • 2.向栈中压入元素(stackpush)
      • 3.获取栈顶元素(stacktop)
      • 4.弹出栈顶元素(stackpop)
      • 5.销毁栈(stackdestroy)
      • 6.判断栈是否为空(stackempty)
      • 7.括号匹配验证函数(isValid)
    • 栈的应用与总结

栈的应用

在编程的世界里,经常会遇到各种各样需要处理符号匹配的问题,其中括号匹配是一个经典的基础案例。今天,我们就来深入探讨一段用 C 语言实现括号匹配验证的代码,同时了解栈(Stack)这种数据结构在其中发挥的重要作用。

代码概览

首先,让我们来看一下这段代码的整体结构。代码定义了一个名为stack的结构体,用于表示栈的数据结构,其中包含了一个字符指针arr用于存储栈中的元素,一个整数top用于指示栈顶的位置,以及一个整数capacity表示栈的当前容量。

typedef struct stack
{char *arr;int top;int capacity;
}stack;

接下来,是一系列对栈进行操作的函数,包括初始化栈(stackInit)、向栈中压入元素(stackpush)、获取栈顶元素(stacktop)、弹出栈顶元素(stackpop)、销毁栈(stackdestroy)以及判断栈是否为空(stackempty)。这些函数构成了栈操作的基本接口,为后续的括号匹配验证提供了基础支持。

栈操作函数详解

1.初始化栈(stackInit)

void stackInit(stack* ps)
{ps->arr = NULL;ps->top = ps->capacity = 0;
}

这个函数的作用是初始化一个栈。它将栈的数组指针arr设为NULL,表示栈中还没有分配内存空间。同时,将栈顶指针top和栈的容量capacity都初始化为 0。

2.向栈中压入元素(stackpush)

void stackpush(stack* ps, char s)
{if(ps->top == ps->capacity){int newcapacity = ps->capacity == 0? 4 : ps->capacity*2;char* tmp = realloc(ps->arr,sizeof(char)*newcapacity);if(tmp == NULL){exit(1);}ps->arr = tmp;ps->capacity = newcapacity;}ps->arr[ps->top++] = s;
}

stackpush函数用于将一个字符s压入栈中。在压入元素之前,首先检查栈是否已满。如果栈的当前容量capacity与栈顶指针top相等,说明栈已满,需要进行扩容操作。这里采用了一种动态扩容的策略,当栈为空时,新的容量设为 4;否则,将当前容量翻倍。通过realloc函数重新分配内存空间,如果分配失败,则调用exit(1)终止程序。成功分配内存后,更新栈的容量,并将元素 s存入栈顶位置,然后将栈顶指针top加 1。

3.获取栈顶元素(stacktop)

char stacktop(stack *ps)
{if(ps->top == 0)exit(1);return ps->arr[ps->top-1];
}

stacktop函数用于获取栈顶元素。在获取元素之前,先检查栈是否为空。如果栈为空(即top为 0),则调用exit(1)终止程序,因为空栈是无法获取栈顶元素的。否则,返回栈顶指针top减 1 位置的元素,即栈顶元素。

4.弹出栈顶元素(stackpop)

void stackpop(stack* ps)
{ps->top--;
}

stackpop函数的实现非常简洁,它只是将栈顶指针top减 1,从而实现弹出栈顶元素的操作。需要注意的是,这里并没有真正释放栈顶元素所占用的内存空间,只是逻辑上移除了栈顶元素。

5.销毁栈(stackdestroy)

void stackdestroy(stack*ps)
{free(ps->arr);ps->arr = NULL;ps->top = ps->capacity = 0;
}

stackdestroy函数用于销毁栈。它首先通过free函数释放栈数组所占用的内存空间,然后将栈的数组指针arr设为NULL,防止出现野指针。最后,将栈顶指针top和栈的容量capacity都重置为 0。

6.判断栈是否为空(stackempty)

bool stackempty(stack* ps)
{if(ps->top == 0){return true;}return false;
}

stackempty函数用于判断栈是否为空。它只需检查栈顶指针top是否为 0,如果为 0,则返回true表示栈为空;否则返回false表示栈不为空。

7.括号匹配验证函数(isValid)

bool isValid(char* s) {stack st;stackInit(&st);char* pi = s;while(*pi != '\0'){if(*pi == '(' || *pi == '[' || *pi =='{')stackpush(&st,*pi);else{if(stackempty(&st)){stackdestroy(&st);return false;}char top = stacktop(&st);if((top == '('&&*pi != ')')||(top == '['&& *pi != ']')||(top=='{'&&*pi != '}')){stackdestroy(&st);return false;    }stackpop(&st);}pi++;}bool ret = stackempty(&st) ? true : false;stackdestroy(&st);return ret;
}

isValid函数是整个代码的核心,用于判断给定字符串s中的括号是否有效匹配。它首先初始化一个栈st,然后通过一个指针pi遍历字符串s。
当遍历到一个左括号((、[或{)时,将其压入栈中。当遍历到一个右括号()、]或})时,首先检查栈是否为空。如果栈为空,说明没有匹配的左括号,直接销毁栈并返回false。否则,获取栈顶元素,判断栈顶元素与当前右括号是否匹配。如果不匹配,则销毁栈并返回false。如果匹配,则弹出栈顶元素,表示成功匹配一对括号。
当字符串遍历结束后,检查栈是否为空。如果栈为空,说明所有括号都成功匹配,返回true;否则返回false。无论结果如何,最后都要销毁栈,释放所占用的内存资源。

栈的应用与总结

栈作为一种后进先出(LIFO, Last In First Out)的数据结构,在许多场景中都有着广泛的应用。在括号匹配验证这个问题中,栈的特性恰好能够满足我们的需求。通过将左括号压入栈中,当遇到右括号时从栈中弹出相应的左括号进行匹配,能够有效地判断括号是否正确配对。

相关文章:

括号匹配问题--栈

括号匹配问题 栈的应用代码概览栈操作函数详解1.初始化栈(stackInit)2.向栈中压入元素(stackpush)3.获取栈顶元素(stacktop)4.弹出栈顶元素(stackpop)5.销毁栈(stackdest…...

原生SSE实现AI智能问答+Vue3前端打字机流效果

实现流程: 1.用户点击按钮从右侧展开抽屉(drawer),打开模拟对话框 2.用户输入问题,点击提问按钮,创建一个SSE实例请求后端数据,由于SSE是单向流,所以每提一个问题都需要先把之前的实…...

LLC工作模态详解

1以半桥LLC谐振变换器为例,主开关Q1、Q2构成半桥结构,其驱动信号为固定占空比50%的互补信号,并且在上下桥臂之间应有死区时间。 谐振电感Ls、谐振电感Cs和变压器励磁电感Lm共同构成谐振槽路,具有两个谐振频率: 谐振电…...

线代第三课:n阶行列式

引言 行标取自然排列 不同行不同列的3个元素相乘 列标取排列的所有可能 列标排列的逆序数的奇偶性决定符号,- n阶行列式 第一种:按行展开 (1) 行标取自然排列 (2) 列标取排列的所有可能 (PS:可以理解为随意取) (3) 从…...

机器学习的一百个概念(10)假阳性率

前言 本文隶属于专栏《机器学习的一百个概念》,该专栏为笔者原创,引用请注明来源,不足和错误之处请在评论区帮忙指出,谢谢! 本专栏目录结构和参考文献请见[《机器学习的一百个概念》 ima 知识库 知识库广场搜索: 知识库创建人机器学习@Shockang机器学习数学基础@Shocka…...

GitHub 克隆/下载失败的解决方案

🚀 GitHub 下载/克隆失败?一招搞定代理配置与回滚! 在国内使用 Git 操作 GitHub 时,经常会遇到以下问题: ❌ 下载失败、超时 ❌ Failed to connect to github.com port 443 ❌ SSL certificate problem 本文将详细讲解…...

pulsar proxy详解

什么是 Pulsar Proxy? Pulsar Proxy 是 Apache Pulsar 中的一个可选组件,作用是作为客户端与 Pulsar Brokers 之间的中间网关层。它并不是 Pulsar 核心功能必须的部分,但在特定场景下(如复杂的网络环境、安全性需求或动态集群管理…...

C++ Socket优化实战:提升网络应用的性能与效率

🧑 博主简介:CSDN博客专家、CSDN平台优质创作者,高级开发工程师,数学专业,拥有高级工程师证书;擅长C/C、C#等开发语言,熟悉Java常用开发技术,能熟练应用常用数据库SQL server,Oracle…...

STM32单片机入门学习——第30节: [9-6] FlyMcu串口下载STLINK Utility

写这个文章是用来学习的,记录一下我的学习过程。希望我能一直坚持下去,我只是一个小白,只是想好好学习,我知道这会很难,但我还是想去做! 本文写于:2025.04.09 STM32开发板学习——第30节: [9-6] FlyMcu串口下载&STLINK Utility 前言开发…...

Qt容器类在元对象系统中使用

解释 “QVector没有被注册到Qt的元对象系统中”这句话的意思是&#xff1a;QVector<double>这种数据类型没有被Qt的元对象系统&#xff08;Meta-Object System&#xff09;识别和管理。Qt的元对象系统是Qt框架的核心部分&#xff0c;它提供了信号与槽机制、动态属性系统…...

亮相CMEF,美的医疗全维度打造智慧医疗新生态

当下&#xff0c;医疗科技革命的浪潮正汹涌而来&#xff0c;AI技术在中国医疗器械领域迅猛发展&#xff0c;释放出巨大的潜力。 4月8日&#xff0c;在第91届中国国际医疗器械博览会&#xff08;CMEF&#xff09;上&#xff0c;2025美的医疗年度新品发布暨中国脊梁守护计划启动…...

数据库视图讲解(view)

一、为什么需要视图 二、视图的讲解 三、总结 一、为什么需要视图 视图一方面可以帮我们使用表的一部分而不是所有的表&#xff0c;另一方面也可以针对不同的用户制定不同的查询视图。 比如&#xff0c;针对一个公司的销售人员&#xff0c;我们只想给他看部分数据&#xff0c…...

TQTT_KU5P开发板教程---文件的烧写与程序固化

文档功能介绍 本文档所描述的为文件的烧写固化&#xff0c;利用spi芯片将程序固化带芯片上&#xff0c;可以让开发板在重新上电时也可以跑程序。我们所使用的芯片型号为mt25qu256-spi-x1_x2_x4.本次实验采用的在led_shift项目的基础上将流水灯程序固化到flash芯片上&#xff0c…...

进度管理__制订进度计划_资源平衡和资源平滑

本文讲解的资源平衡与资源平滑&#xff0c;是制订进度计划的工具与技术的第3项&#xff1a; 资源优化。 1. 资源平衡 资源平衡是为了在资源需求与资源供给之间取得平等&#xff0c; 根据资源制约因素对开始日期和完成日期进行调整的一种技术。 如果共享资源或关键资源只在特定…...

【ISP】ISP pipeline(AI)

ISP Pipeline 全流程概览 ISP&#xff08;Image Signal Processing&#xff0c;图像信号处理&#xff09;流程通常从原始 Bayer 数据出发&#xff0c;经过一系列模块处理&#xff0c;逐步完成图像校正和增强&#xff0c;最终生成用于显示或编码的标准图像。常见处理模块包括&a…...

C++ RAII 的用途及业务代码实现案例

C RAII 的用途及业务代码实现案例 RAII 的核心概念 RAII (Resource Acquisition Is Initialization&#xff0c;资源获取即初始化) 是 C 的核心编程范式&#xff0c;其核心思想是&#xff1a; 资源获取与对象构造绑定资源释放与对象析构绑定利用 C 对象生命周期自动管理资源…...

RVOS-2.基于NS16550a ,为os添加终端交互功能。

2.1 实验目的 为os添加uart功能&#xff0c;通过串口实现开发板与PC交互。 2.1 硬件信息 QEMU虚拟SoC含有 虚拟NS16550A设备 。 不同的地址线组合&#xff08;A2、A1、A0&#xff09;对应的读写模式和寄存器如下所示&#xff1a; 2.2 NS16550a 的初始化 线路控制寄存器&#…...

#SVA语法滴水穿石# (004)关于 ended 和 triggered 用法

在 SystemVerilog 断言(SVA, SystemVerilog Assertions)中,ended 是一个用于 序列(sequence) 的关键字,它表示某个序列(sequence)在特定时间点已经成功匹配(即“结束”)。 ended 主要用于 同步不同序列的时间关系,尤其是在多序列组合或属性(property)中需要对齐时…...

软件学报 区块链论文 截止2025年4月 录用汇总 附pdf下载

截止 2025年4月 软件学报 2024年 区块链论文 录用汇总 附pdf下载 1 Title: 基于多父链辅助工作量证明共识机制的后量子区块链系统 Authors: Key words: 区块链;后量子密码;共识机制;辅助工作量证明 Abstract: 随着量子计算机的发展,对于以传统椭圆曲线数字签名为基石的公…...

损失函数篇——针对YOLO-MIFIN模型

1. 总损失函数&#xff08;公式9&#xff09; L all λ conf L conf λ cls L cls λ loc L loc (9) L_{\text{all}} \lambda_{\text{conf}} L_{\text{conf}} \lambda_{\text{cls}} L_{\text{cls}} \lambda_{\text{loc}} L_{\text{loc}} \tag{9} Lall​λconf​Lconf​λ…...

【MySQL 数据库】增删查改操作CRUD(上)

&#x1f525;博客主页&#x1f525;&#xff1a;【 坊钰_CSDN博客 】 欢迎各位点赞&#x1f44d;评论✍收藏⭐ 目录 1. CRUD 简介 2. Create -- 新增 2.1 语法 2.2 练习 3. Retrieve -- 检索 3.1 Select -- 查询 3.1.1 全列查询 3.1.2 指定列查询 3.1.3 表达式查询 3.…...

pycharm 有智能提示,但是没法自动导包,也就是alt+enter无效果

找到file->settings->editor->inspections 把python勾选上&#xff0c;原来不能用是因为只勾选了一部分。...

web前端: 什么是web?

web前端指的是利用HTML、CSS、JavaScript等各种web技术&#xff0c;做出能在浏览器上运行且用户可见的界面&#xff0c;比如网站网页、APP软件界面、游戏前端界面等。web前端主要包括web全局架构、web视觉表现和web交互效果这三部分。 WEB发展史 Web&#xff08;World Wide We…...

Java 开发中主流安全框架的详细对比,涵盖 认证、授权、加密、安全策略 等核心功能,帮助开发者根据需求选择合适的方案

以下是 Java 开发中主流安全框架的详细对比&#xff0c;涵盖 认证、授权、加密、安全策略 等核心功能&#xff0c;帮助开发者根据需求选择合适的方案&#xff1a; 1. 主流安全框架对比表 框架名称类型核心功能适用场景优点缺点官网/文档Spring Security企业级安全框架认证、授…...

Linux网络编程——TCP协议格式、可靠性分析

目录 一、前言 二、TCP协议格式 三、TCP的可靠性 TCP协议的确认应答机制 总结 四、TCP协议的缓冲区及流量控制 五、 TCP流量控制 六、TCP报文类型 标记位 一、前言 在上一篇文章中&#xff0c;我们重点介绍了UDP协议格式的一些内容。在本文中介绍的便是TCP协议格式的…...

【深度学习】Downstream Model:预训练模型的下游应用与微调技术

Downstream Model&#xff1a;预训练模型的下游应用与微调技术 文章目录 Downstream Model&#xff1a;预训练模型的下游应用与微调技术1 什么是Downstream Model&#xff08;下游模型&#xff09;2 预训练模型与下游任务的关系3 微调技术与迁移学习微调的必要性高效迁移学习参…...

C# ref out关键字 理解学习记录

ref 在传参是可以以指针的方式传递&#xff0c;而不是传参数的值 举例&#xff0c;函数返回void ,局部变量要传参后得到结果&#xff1a; ref传参前要实例化赋值&#xff0c;而函数体内不一定要赋值 out 传参前不一定要赋值&#xff0c;而函数体内一定要赋值 &#xff0c;与r…...

网络建设与运维神州数码DCN VRF虚拟路由转发 路由表隔离

作用&#xff1a; 通过在一台路由器或者三层交换机上创建多张路由表实现数据的隔离&#xff0c;常用与MPLS VPN、防火墙.... 如果发送的包在同一VRF中&#xff0c;则查表&#xff0c;查找到匹配的路由条目后&#xff0c;将指示的端口转发给下一跳 如果不在同一VRF中则丢弃。…...

Python中的AdaBoost分类器:集成方法与模型构建

引言 在机器学习领域&#xff0c;集成方法&#xff08;Ensemble Methods&#xff09;是一种通过结合多个基学习器来提高模型性能的技术。AdaBoost&#xff08;Adaptive Boosting&#xff09;是集成方法中的一种经典算法&#xff0c;它通过迭代训练多个弱分类器&#xff0c;并将…...

11:00开始面试,11:08就出来了,问的问题有点变态。。。

从小厂出来&#xff0c;没想到在另一家公司又寄了。 到这家公司开始上班&#xff0c;加班是每天必不可少的&#xff0c;看在钱给的比较多的份上&#xff0c;就不太计较了。没想到8月一纸通知&#xff0c;所有人不准加班&#xff0c;加班费不仅没有了&#xff0c;薪资还要降40%…...