news 2026/5/26 6:36:44

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
数据结构中括号匹配的问题

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; }

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/26 5:46:16

提示工程架构师进阶:AI提示系统创新突破中的少样本学习技术

提示工程架构师进阶&#xff1a;少样本学习如何突破AI提示系统的能力边界&#xff1f; 摘要/引言&#xff1a;为什么你的提示系统总卡在“需要更多示例”&#xff1f; 清晨9点&#xff0c;某电商企业的AI产品经理小夏冲进会议室&#xff1a;“昨天上线的‘生鲜退货’意图识别…

作者头像 李华
网站建设 2026/5/24 0:26:46

【Dify扩展开发必知】:Agent工具集成的7大坑,90%开发者都踩过

第一章&#xff1a;Agent工具集成的核心概念与Dify架构解析在构建现代AI驱动的应用系统中&#xff0c;Agent工具集成已成为实现自动化决策与复杂任务处理的关键技术路径。通过将智能代理&#xff08;Agent&#xff09;与外部工具链深度整合&#xff0c;系统能够动态调用函数、访…

作者头像 李华
网站建设 2026/5/24 18:22:07

Wan2.2-T2V-A14B如何生成逼真的水下生物视频?

当AI开始“理解”生命&#xff0c;创作便有了灵魂 你有没有想过&#xff0c;一段深海章鱼在珊瑚丛中灵巧穿梭的镜头&#xff0c;不再需要潜水员潜入300米暗流、扛着摄像机守候数周&#xff1f;现在&#xff0c;只需一句精准描述&#xff0c;AI就能为你“现场直播”这场海底奇观…

作者头像 李华
网站建设 2026/5/25 14:48:10

【Dify缓存机制深度解析】:视频字幕检索性能提升的5大关键周期配置

第一章&#xff1a;Dify缓存机制在视频字幕检索中的核心作用在高并发的视频内容平台中&#xff0c;快速准确地检索字幕信息是提升用户体验的关键。Dify 框架通过其高效的缓存机制&#xff0c;在视频字幕检索场景中显著降低了数据库查询压力&#xff0c;同时提升了响应速度。该机…

作者头像 李华
网站建设 2026/5/25 9:27:49

CubeMx安装离线hal固件库实现离线生成的代码工程

这里写自定义目录标题下载hal库固件包进入ST官网产品选择器页面往下翻选择STM32F4系列选择对应的版本选择接受然后下载&#xff08;这里必须要登录ST注册的邮箱密码才可以下载&#xff09;CubeMX导入固件包打开CubeMX选择Help导入安装离载固件包生成工程&#xff0c;可观看我ST…

作者头像 李华
网站建设 2026/5/24 11:32:42

LobeChat能否用于创作小说?叙事结构生成能力评估

LobeChat能否用于创作小说&#xff1f;叙事结构生成能力评估 在数字创作的浪潮中&#xff0c;越来越多作家开始尝试借助人工智能完成从灵感到成稿的全过程。尤其是当一个工具既能保持专业级的文本质量&#xff0c;又能提供直观、灵活的操作体验时&#xff0c;它便有可能重塑整个…

作者头像 李华