栈的实现以及c语言解决括号匹配问题

一、栈的实现

1、头文件

typedef int STDataType;
typedef struct Stack
{STDataType* _a;int _top;		// 栈顶int _capacity;  // 容量 
}Stack;
// 初始化栈 
void StackInit(Stack* ps); 
// 入栈 
void StackPush(Stack* ps, STDataType data); 
// 出栈 
void StackPop(Stack* ps); 
// 获取栈顶元素 
STDataType StackTop(Stack* ps); 
// 获取栈中有效元素个数 
int StackSize(Stack* ps); 
// 检测栈是否为空,如果为空返回非零结果,如果不为空返回0 
int StackEmpty(Stack* ps); 
// 销毁栈 
void StackDestroy(Stack* ps); 

2、函数实现

a、初始化

top为栈顶的位置但是给其初始化时要考虑其初始化为什么(因为我们访问栈顶元素时,是通过top实现的,即下标访问,且栈的特点为先出后进,所以用栈时只考虑栈顶元素,其他位置不考虑),所以会有如下情况:

这里我选择第二种方式,因为判断栈空间时直接比较top和capacity的大小即可:
 

// 初始化栈 
void StackInit(Stack* ps)
{assert(ps);ps->_a = NULL;ps->_capacity = ps->_top = 0;//此时top为栈顶元素的下一个位置
}

b、销毁栈

void StackDestroy(Stack* ps)
{assert(ps);free(ps->_a);ps->_a = NULL;ps->_capacity = ps->_top = 0;//为了严谨置为0
}

c、入栈

入栈之前要像和实现顺序表的时候,去判断空间是否够用:

void StackPush(Stack* ps, STDataType data)
{assert(ps);int newcapacity = 0;STDataType* tmp = NULL;if (ps->_top == ps->_capacity){if (ps->_capacity == 0)//为0给空间为4{newcapacity = 4;}else//扩二倍{newcapacity = 2 * ps->_capacity;}//int newcapacity = pst->capacity == 0 ? 4 : pst->capacity * 2;也可以直接一个三目操作符搞定tmp = (STDataType*)realloc(ps->_a, newcapacity * sizeof(STDataType));if (tmp == NULL){perror("realloc fail");exit(0);// 退出程序}ps->_capacity = tmp;ps->_capacity = newcapacity;}ps->_a[ps->_top] = data;//top指向下一个位置直接加ps->_top++;
}

d、出栈

出栈其实非常简单只需要将top减1就可以了,但要注意top不能减到0,因为指向0的时候就没有元素了,数组大小为0;

void StackPop(Stack* ps)
{assert(ps);assert(ps->_top > 0);ps->_top--;
}

e、获取栈顶元素

STDataType StackTop(Stack* ps)
{assert(ps);assert(ps->_top > 0);//保证有栈顶元素return ps->_a[ps->_top - 1];
}

f、获取栈元素个数

int StackSize(Stack* ps)
{assert(ps);assert(ps->_top >= 0);//数组元素个数不能为负return ps->_top://top就是数组元素个数
}

g、判断栈是否为空

int StackEmpty(Stack* ps)
{assert(ps);return ps->_top == 0;//返回这个表达式的结果即可
}

二、括号匹配问题

这题恰好用到了我们刚昂实现的栈的知识,我们就会有这样的思路,如果为左括号则入栈,再将栈顶元素和下一个字符匹配,如果匹配成功则出栈,否则继续匹配,直到字符串读完.(这里注意题目中传的是字符串的首地址,那么我们可以通过一个一个解引用,来实现入栈)。

实际上我们也可以先将所以的左括号入完栈后再一个一个进行比较,如果不对字符串向下走,但是这样会遍历两次,时间复杂度为O(N),那么,我们不如变入栈边比较,因为会对字符串进行调整,对比成功的直接出栈 ,所以不用担心会对比两次的情况,时间复杂度还是O(N)。

那么有没有可能出现错过的情况?这里我们就要认真审题

随便 举个例子:我们会发现左括号和右括号总是成对出现的,当左括号入栈时,下一个一定是其对应的右括号。

这是第一种特殊情况,如果字符穿读完栈不为空时,说明不匹配,最后出循环时要加一个判断是否为空

这是第二种特殊情况,当开始为右边括号,则开始不入栈,最后出栈栈为空,根据前面,判断为真,但是为假,所以我们要在比对前加一步判断栈是否为空的情况,如果为空,则为假(因为没有左括号和右括号匹配)。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Transformer详解:从放弃到入门(三)

上篇文章中我们了解了多头注意力和位置编码,本文我们继续了解Transformer中剩下的其他组件。 层归一化 层归一化想要解决一个问题,这个问题在Batch Normalization的论文中有详细的描述,即深层网络中内部结点在训练过程中分布的变化问题。  …

Redis(持久化)

文章目录 1.RDB1.介绍2.RDB执行流程3.持久化配置1.Redis持久化的文件是dbfilename指定的文件2.配置基本介绍1.进入redis配置文件2.搜索dbfilename,此时的dump.rdb就是redis持久化的文件3.搜索dir,每次持久化文件,都会在启动redis的当前目录下…

Day 26 数据库日志管理

数据库日志管理 一:日志管理 1.日志分类 ​ 错误日志 :启动,停止,关闭失败报错。rpm安装日志位置 /var/log/mysqld.log ​ 通用查询日志:所有的查询都记下来 ​ 二进制日志:实现备份,增量备份…

设置多用户远程登录windows server服务器

##设置多用户远程登录windows server服务器 ###1、远程登录windows server 2016 运行—>mstsc—>远程IP地址—>用户和密码 2、远程windows服务器设置多用户策略 运行—>gpedit.msc->计算机配置—管理模板—windows组件—远程桌面服务—远程桌面会话主机----连…

语音识别--kNN语音指令识别

⚠申明: 未经许可,禁止以任何形式转载,若要引用,请标注链接地址。 全文共计3077字,阅读大概需要3分钟 🌈更多学习内容, 欢迎👏关注👀【文末】我的个人微信公众号&#xf…

HTML学习

一、HTML HTML&#xff08;Hypertext Markup Language&#xff09;是一种用于创建网页的标准标记语言。 标记语言是一套标记标签。 HTML文档也叫做web页面。 HTML标签 HTML标签是由尖括号<>包围的关键词&#xff0c;通常成对出现。 标签对中的第一个标签是开始标签&am…

爬虫学习(4)每日一笑

代码 import requests import re import osif __name__ "__main__":if not os.path.exists("./haha"):os.makedirs(./haha)url https://mlol.qt.qq.com/go/mlol_news/varcache_article?docid6321992422382570537&gameid3&zoneplat&webview…

京东生产环境十万并发秒杀系统三高架构

文章目录 三高——高并发、高可用、高可扩展用数据库乐观锁解决超卖阿里巴巴&#xff1a;为了提升数据库性能&#xff0c;对数据库的源码级别做了改造——在DB内部实现内存队列&#xff0c;一次性接收很多的请求&#xff0c;一次性更新。京东&#xff1a;redis&#xff0c;mq&a…

python实验三 实现UDP协议、TCP协议进行服务器端与客户端的交互

实验三 实验题目 1、请利用生成器构造一下求阶乘的函数Factorial()&#xff0c;定义一个函数m()&#xff0c;在m()中调用生成器Factorial()生成小于100的阶乘序列存入集合s中&#xff0c;输出s。 【代码】 def factorial():n1f1while 1:​ f * n​ yield (f)​ n1…

Map集合的实现类~TreeMap

重复依据&#xff1a;通过对键进行排序 先创建Student类&#xff0c;并在主函数new对象&#xff0c;然后创建TreeMap&#xff1a; 建立红黑树&#xff0c;需要在Student类后面实现类的接口&#xff1a; 重写其中的compareTo方法&#xff1a; 或者可以自定义比较器&#xff1a; …

element-plus el-cascader 懒加载实现-省市区街道选择及回显

大概思路&#xff1a; 准备一个接口可以通过父Id,查询到下一级省市区街道的信息&#xff1b;如下方的getRegionListOne确定后端的数据结构&#xff0c;需要在created里边处理数据回显逻辑el-cascader接收的数据格式是[‘’,‘’,‘’];后端的数据格式多为[{provinceId: ‘’, …

2005-2021年全国各地级市生态环境注意力/环保注意力数据(根据政府报告文本词频统计)

2005-2021年全国各地级市生态环境注意力/环保注意力数据&#xff08;根据政府报告文本词频统计&#xff09; 2005-2021年全国各地级市生态环境注意力/环保注意力数据&#xff08;根据政府报告文本词频统计&#xff09; 1、时间&#xff1a;2005-2021年 2、范围&#xff1a;2…