news 2026/6/14 23:04:22

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

作者头像

张小明

前端开发工程师

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/6/15 11:51:44

为什么90%的科研新人做不好表观遗传分析?,R语言实操避坑清单大公开

第一章&#xff1a;为什么90%的科研新人做不好表观遗传分析&#xff1f;表观遗传分析涉及DNA甲基化、组蛋白修饰和非编码RNA等多种分子机制&#xff0c;其数据分析不仅要求掌握生物学背景知识&#xff0c;还需具备一定的生物信息学技能。许多科研新人在入门阶段常因忽略数据预处…

作者头像 李华
网站建设 2026/6/15 13:06:39

【Dify结果融合优化秘籍】:3步提升混合检索准确率90%+

第一章&#xff1a;混合检索与Dify结果融合概述在现代智能问答与信息检索系统中&#xff0c;单一检索方式往往难以满足复杂场景下的精度与召回率需求。混合检索通过结合多种检索策略——如关键词匹配、向量语义检索和图结构检索——实现更全面的信息覆盖。与此同时&#xff0c;…

作者头像 李华
网站建设 2026/6/15 5:23:13

【私有化Dify部署必看】:详解端口配置最佳实践与避坑指南

第一章&#xff1a;私有化Dify部署中的端口配置概述在私有化部署 Dify 时&#xff0c;合理的端口配置是确保服务正常运行和安全访问的关键环节。Dify 作为一个支持 AI 工作流编排与应用发布的平台&#xff0c;其组件之间依赖多个网络端口进行通信。正确开放和映射这些端口&…

作者头像 李华
网站建设 2026/6/14 16:39:20

大数据领域数据挖掘的安全管理

大数据领域数据挖掘的安全管理 关键词&#xff1a;大数据安全、数据挖掘、隐私保护、访问控制、加密技术、安全审计、合规管理 摘要&#xff1a;本文深入探讨大数据环境下数据挖掘过程中的安全管理挑战与解决方案。文章首先分析大数据安全的基本概念和面临的独特挑战&#xff0…

作者头像 李华
网站建设 2026/6/15 14:50:19

全球顶尖研究机构都在用的溯源方法,R语言实现竟如此简单?

第一章&#xff1a;环境监测中污染物溯源的核心挑战在环境监测领域&#xff0c;准确识别和追踪污染物来源是制定有效治理策略的前提。然而&#xff0c;由于污染源的多样性和环境介质的复杂性&#xff0c;污染物溯源面临诸多技术与方法上的挑战。数据采集的时空异质性 环境中的污…

作者头像 李华