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

数据结构中括号匹配的问题

1.主要是运用栈这种操作,最基本操作运算,判空,入栈,出栈,对于括号来说,当检测到第一个括号为左括号就压入栈中,如果不是左括号而且栈中没有任何元素说明匹配失败,如果栈定元素是左括号但是和需要匹配的不是同类型的括号说明匹配失败了,如果匹配到最后栈中剩余的还有元素,说明左括号和右括号的数量不相对,肯定有问题,如果一个栈是空的话直接判空函数会返回一个TRUE如果不是空栈会返回flase,可以当作最后返回的值,然后进行判断,特别注意中文的符号和英文的符号不一样,如果len的长度异常就是输入中文了。

2.在进行敲代码的时候应该从主函数开始敲起,敲这敲着感觉自己需要什么了以后再去创建相应的函数,切记一股脑的从上往下直接敲,先大致阅读一边,有一个大局观,然后跟着敲一个边,在脑海里想清楚然后记住,把这个函数删除自己再敲一边化成自己的东西。

#define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<string.h>//strlen函数头文件 #include<stdbool.h> #define MAXSIZE 100 //最大的容量是100,最多能够检测100个括号的匹配 typedef struct { char data[MAXSIZE];//因为字符是char类型的这里创建的时候就是char,要想明白创建的是什么类型的结构体 int top;//用来栈顶元素的判断 }SeqStack; //初始化 void InitStack(SeqStack* Ps) { Ps->top = -1; } //判断栈是不是为空 bool IsEmpty(SeqStack* Ps) { return Ps->top == -1;//如果等于-1说明是空栈不能出栈,值为真,如果不是空栈值为假为0 } bool Push(SeqStack* Ps, char elem) { if (Ps->top == MAXSIZE - 1) { printf("栈已经满了\n"); return false;//不能进栈了,栈已经满了 } Ps->top += 1;//因为top的值是从-1开始的,添加值是应该从后一个位置开始添加,先增加再赋值 Ps->data[Ps->top] = elem; return true; } bool Pop(SeqStack* Ps, char* elem) { if (Ps->top == -1) { return false; } *elem = Ps->data[Ps->top];//先把值赋值过去,然后再进行减 Ps->top -= 1; return true; } bool BracketCheck(char* str, int len) { SeqStack S;//创建一个变量 InitStack(&S);//然后进行初始化 int i = 0; for (i = 0; i < len; i++) { if (str[i] == '(' || str[i] == '{' || str[i] == '[')//如果这个是左括号就压栈 { Push(&S, str[i]);//压栈的两个操作数,一个是SeqStack*类型,一个是str[i] } else { if (IsEmpty(&S))//判断是不是为空的,这个时候判断是不是左括号的但是数组中没有元素了 { return false; } char TopElem;//顶端元素 Pop(&S, &TopElem);//注意这里是传递地址调用,能改变元素的值 if(((str[i]=='}') && (TopElem!='{')) || ((str[i] == ')') && (TopElem != '(')) || ((str[i] == ']') && (TopElem != '['))) { return false; } } } return IsEmpty(&S); } int main() { char str[MAXSIZE] = { 0 };//注意这个变量是存放数据的,而用结构体创建的是用来进行栈的操作的 printf("请输入你要匹配的括号\n"); scanf("%s", str);//输入括号。特别注意中文的符号和英文的符号不一样,如果len的长度异常就是输入中文了 int len = strlen(str);//求字符串长度 printf("当前匹配的括号数量是%d\n", len);//增加和用户的交互 printf("---------开始判断-------\n"); if (BracketCheck(str, len))//Bracketcheck匹配成功会返回true否则返回flase { printf("匹配成功!\n"); } else { printf("匹配失败!\n"); } return 0; }

http://www.jsqmd.com/news/100597/

相关文章:

  • Dify Tesseract 更新为何如此高效?解密其背后鲜为人知的差分同步算法
  • Dify并行任务调度原理剖析(从入门到精通的4个阶段)
  • 【稀缺资源】临床数据亚组分析核心算法(R代码+案例数据免费送)
  • (Docker MCP服务注册性能优化秘籍):亿级请求下的稳定注册实践
  • 【Dify缓存机制深度解析】:视频字幕检索性能提升的5大关键周期配置
  • 2025年十大高口碑交互数字人推荐榜单,实现智能互动新体验
  • 静态综合实验
  • 基于改进粒子群算法的配电网重构改进探索
  • 数据库服务器挂载新硬盘全流程端到端运营,实操指引
  • 【Dify与Spring AI兼容性深度解析】:掌握版本匹配的5大核心原则
  • 10 个降AI率工具,研究生高效避坑指南
  • 年度精选:数字人公司推荐,帮你提升企业效率的最佳选择
  • 生物信息学高手进阶之路(R语言RNA分析全解析)
  • 从零搭建智能工作流,手把手教你玩转Dify可视化编辑器
  • LobeChat能否实现AI健身教练?运动计划定制与指导
  • 【华尔街都在用的风险对冲方法】:基于R语言的GARCH模型实战解析
  • 如何用Dify实现毫秒级并行响应?一线架构师亲授调优秘方
  • 【Dify扩展开发必知】:Agent工具集成的7大坑,90%开发者都踩过
  • 别再被网络问题拖累!云原生Agent Docker配置的7个关键步骤
  • Docker Scout漏洞响应机制深度解析,90%团队忽略的修复盲区
  • Dify + 视觉模型打造文生视频工作流
  • Dify解析加密PDF总是报错?掌握这4个关键点让你效率提升300%
  • 【生产环境必备】:构建自愈系统的Docker Compose健康检查策略
  • 全球顶尖研究机构都在用的溯源方法,R语言实现竟如此简单?
  • 人形机器人控制系统核心芯片从SoC到ASIC的进化路径(版本A)
  • 吴恩达深度学习课程四:计算机视觉 第二周:经典网络结构 (二)残差网络
  • 2025年中国WMS系统厂商盘点:本土品牌市场动态与选型参考
  • 揭秘Dify Agent元数据定义:3步完成工具注册的标准化配置
  • 8 个自考文献综述工具,降AIGC查重率AI推荐
  • (智能Agent容器资源控制终极指南):从入门到精通的6大核心配置策略